日付をmm/yy形式で表示するためのJQuery日付ピッカーが含まれているページがあります。私は最初のJQueryを作成していませんでしたが、あまり詳しくないため、これは単純な問題かもしれませんが、ユーザーが[完了]ボタンをクリックすると、日付ピッカーが1秒間消えてから、ユーザーがクリックしたかのように開きます。再びテキストボックスに。
日付ピッカーをインスタンス化するために使用されるコードは次のとおりです。
$(function() {
$('.datepicker').datepicker({
changeMonth: true,
changeYear: true,
showButtonPanel: true,
dateFormat: 'mm/yy',
onClose: function(dateText, inst) {
var month = $("#ui-datepicker-div .ui-datepicker-month :selected").val();
var year = $("#ui-datepicker-div .ui-datepicker-year :selected").val();
$(this).datepicker('setDate', new Date(year, month, 1));
},
beforeShow: function(input, inst) {
if ((datestr = $(this).val()).length > 0) {
year = datestr.substring(datestr.length - 4, datestr.length);
//month = jQuery.inArray(datestr.substring(0, datestr.length - 5), $(this).datepicker('option', 'monthNames'));
month = datestr.substring(0, datestr.length - 5);
$(this).datepicker('option', 'defaultDate', new Date(year, month-1, 1));
$(this).datepicker('setDate', new Date(year, month-1, 1));
}
}
});
$("#datepicker").mousedown(function() {
$('#ui-datepicker-div').toggle();
});
});
しばらくグーグルした後、マウスダウンハンドラーを追加しました。これにより、ページの日付ピッカーから離れた場所をクリックすると、期待どおりに閉じますが、完了ボタンをクリックしても、実際には日付ピッカーは閉じません。