我能够使用Datepicker加载和重新打开jQueryUI Dialogs作为我尝试过的所有浏览器中的第一个元素...除了IE 9。 如果Datepicker是Dialog打开时获得焦点的第一个元素,则Datepicker将自动启动。我能够在FireFox和Chrome中抑制此行为。 IE 9仍然会在创建时启动Datepicker。
对话框的我的打开和关闭功能是:
open: function (event, ui) {
$('#Date').blur(); // kill the focus
if ($('#Date').hasClass('hasDatepicker')) {
$("#Date").datepicker('enable');
}
else {
$("#Date").datepicker();
}
},
close: function (event, ui) {
$("#Date").datepicker('disable');
}
这是“点击”代码
var dialogs = {};
$('#clicker').click(function (e) {
if (!dialogs['dlg']) {
loadAndShowDialog('dlg');
} else {
dialogs['dlg'].dialog('open');
}
});
var loadAndShowDialog = function (id) {
dialogs[id] = $('#dlg').clone().find('#ChangeMe').attr('id', 'Date').end()
.appendTo(document.body)
.dialog({ // Create the jQuery UI dialog
title: 'Testing',
modal: true,
resizable: true,
draggable: true,
width: 300,
open: see above
close: see above
};
jsfiddle显示此IE9问题http://jsfiddle.net/stocksp/DdRLp/8/
如果没有将Datepicker作为第一个元素,我该怎么办才能让IE表现出来?
答案 0 :(得分:1)
我家里没有IE9,所以试一试:http://jsfiddle.net/DdRLp/10/
我在datepicker输入中添加了一个类,以便于抓取。
$(function() {
$(document).on("dialogcreate", "#dlg", function() {
$(".date_picker").datepicker();
$(".date_picker").datepicker("disable");
});
var dialogs = {};
$('#clicker').click(function(e) {
if (!dialogs['dlg']) {
loadAndShowDialog('dlg');
} else {
dialogs['dlg'].dialog('open');
}
});
var loadAndShowDialog = function(id) {
dialogs[id] = $('#dlg').clone().find('#ChangeMe').attr('id', 'Date').end().appendTo(document.body).dialog({ // Create the jQuery UI dialog
title: 'Testing',
modal: true,
resizable: true,
draggable: true,
width: 300,
open: function(event, ui) {
$("div#dlg form input").blur(); //takes focus off inputs
$(".date_picker").datepicker("enable");
},
close: function(event, ui) {
$(".date_picker").datepicker("disable");
}
});
};
});