0

jquery datepicker の問題に直面しています。

javascript関数で動的に生成されたテキストボックスにjquery datepickerをアタッチしています。

問題は、最初のクリックで日付ピッカーがポップアップしないことです。javascript 関数内にブレークポイントまたはアラートを配置すると、最初のクリックで日付ピッカーがポップアップします。

これは私が使用しているJavaScript関数です:

function CalendarPopUpOnClick(TextBoxId, HiddenFieldId) {
    if (TextBoxId != undefined) {
        $('#' + serverIdPrefix + TextBoxId).keypress(function (event) {
            event.preventDefault();
        });
        var dateTimeDueDate = $('#' + serverIdPrefix + HiddenFieldId).val();
        var dateTimeArrDueDate = dateTimeDueDate.split(" ");
        var dateOnlyDueDate = dateTimeArrDueDate[0];
        $('#' + serverIdPrefix + TextBoxId).val(dateOnlyDueDate);

        setTimeSpanBeginInput = function () {
            var dateTime = $('#' + serverIdPrefix + HiddenFieldId).val();
            var dateTimeArr = dateTime.split(" ");
            var dateOnly = dateTimeArr[0];
            $('#' + serverIdPrefix + TextBoxId).val(dateOnly);
        }
        $('#' + serverIdPrefix + TextBoxId).datepicker({
            dateFormat: 'yy-mm-dd',
            onSelect: function (dateText) {
                $('#' + serverIdPrefix + HiddenFieldId).val(dateText + ' 12:00:00 PM');
            },
            onClose: setTimeSpanBeginInput
        });
    }
}
4

1 に答える 1

0

皆さん、ありがとうございました、

更新が遅くなり申し訳ありません。

私はこれを次のコードで動作させました。

@adeneoが指摘したように、私はC#とAsp.Netを使用しています。

以下に示すように、C#コードビハインドから2つの動的テキストボックスを作成し、テキストボックスのonclikイベントにjavascript関数を追加しています:

 DeliveryDateTextBox.Attributes.Add("onClick", "javascript:CalendarPopUpOnClick('" + DeliveryDateTextBox.ClientID + "','" + Hiddenfield_DeliveryDateTextBox.ClientID + "');");


DueDateTextBox.Attributes.Add("onClick", "javascript:CalendarPopUpOnClick('" + DueDateTextBox.ClientID + "','" + Hiddenfield_DueDateTextBox.ClientID + "');");

Javascriptファイルに次のコードを追加しています:

$(document).ready(function()
{
/* Get id prefixes for checkboxes, checkbox control elements */
var exampleId = $("input[use='proprietary']").attr("id");
var serverIdPrefixEndPos = exampleId.indexOf("exampleID");
serverIdPrefix = exampleId.substring(0,serverIdPrefixEndPos);

/* Datepicker BEGIN */
setTimeSpanBeginInput = function(){
                                var dateTime = $('#'+ serverIdPrefix +'timeSpanFromDeliveryDateHiddenField').val();
                                var dateTimeArr = dateTime.split(" ");
                                var dateOnly = dateTimeArr[0];
                                $('#'+ serverIdPrefix +'timeSpanFromDeliveryDate').val(dateOnly);
                            } //when calendar closed, copy hidden field value to main date field
$('#'+ serverIdPrefix +'timeSpanFromDeliveryDate').datepicker({dateFormat: 'yy-mm-dd', onSelect: function(dateText){ $('#'+ serverIdPrefix +'timeSpanFromDeliveryDateHiddenField').val(dateText + ' 12:00:00 PM'); }, onClose: setTimeSpanBeginInput});

setTimeSpanEndInput = function(){
                                var dateTime = $('#'+ serverIdPrefix +'timeSpanToDateHiddenField').val();
                                var dateTimeArr = dateTime.split(" ");
                                var dateOnly = dateTimeArr[0];
                                $('#'+ serverIdPrefix +'timeSpanToDeliveryDate').val(dateOnly);
                            } //when calendar closed, copy hidden field value to main date field
$('#'+ serverIdPrefix +'timeSpanToDeliveryDate').datepicker({dateFormat: 'yy-mm-dd', onSelect: function(dateText){ $('#'+ serverIdPrefix +'timeSpanToDateHiddenField').val(dateText + ' 12:00:00 PM'); }, onClose: setTimeSpanEndInput});

/* Datepicker END */



});//end document ready 
function CalendarPopUpOnClick(TextBoxId, HiddenFieldId) 
{

    if (TextBoxId) {
        var textBox     = $('#' + serverIdPrefix + TextBoxId),
            hiddenField = $('#' + serverIdPrefix + HiddenFieldId);

        textBox.focus();

         $(":input").bind('paste', function(e) {
        setTimeout(function() {
         var dateval =hiddenField.val();
              if(dateval.indexOf('0001-01-01')==-1)
                textBox.val(  hiddenField.val().split(" ")[0]  );
              else
                textBox.val('');  
        }, 100);
        });            

        textBox.keypress(function(event) {event.preventDefault();});
        hiddenField.keypress(function(event) {event.preventDefault();});
        var dateTime = hiddenField.val();
        var dateTimeArr = dateTime.split(" ");
        var dateOnly = dateTimeArr[0];
        textBox.datepicker({
            dateFormat: 'yy-mm-dd',
            onSelect: function (dateOnly) {
                hiddenField.val(dateOnly + ' 12:00:00 PM');
            },
            onClose: function() {
              var dateval =hiddenField.val();
              if(dateval.indexOf('0001-01-01')==-1)
                textBox.val(  hiddenField.val().split(" ")[0]  );
            }
        });
       textBox.datepicker().datepicker('show');
    }
}
于 2013-05-03T07:51:19.213 に答える