我在我的项目中使用了jQuery datepicker的全局初始化 - 它几乎是这样的代码:
$('body').find(".datepicker").datepicker({dateFormat: 'yy-mm-dd'});
但是,对于某些页面,我需要覆盖此全局定义,并且需要使用此设置(重新)初始化datepicker
:
jQuery(function() {
var date = new Date();
var currentMonth = date.getMonth();
var currentDate = date.getDate();
var currentYear = date.getFullYear();
$('.datepicker').datepicker({
dateFormat: 'yy-mm-dd',
minDate: new Date(currentYear, currentMonth-3, currentDate),
maxDate: new Date(currentYear, currentMonth+3, currentDate)
});
});
问题是第二个代码块(带有minDate
和maxDate
)永远不会被"执行"——datepicker
的原始初始化不会被覆盖。
此问题的一种解决方案是将所有.datepicker
类重命名为 datepicker2
。但是,在页面上有 12 个此类输入,我需要在 3 页上进行此页面更改,因此它像 40 个输入类一样更改。
有没有更好的解决方案?
你必须先摧毁它,然后才能re-init
它。
$( ".selector" ).datepicker( "destroy" );
例
jQuery(function() {
var date = new Date();
var currentMonth = date.getMonth();
var currentDate = date.getDate();
var currentYear = date.getFullYear();
$('.datepicker').datpicker('destroy'); // Destroy it before re-initing
$('.datepicker').datepicker({
dateFormat: 'yy-mm-dd',
minDate: new Date(currentYear, currentMonth-3, currentDate),
maxDate: new Date(currentYear, currentMonth+3, currentDate)
});
});
另一种选择(如您所提到的)是挑选那些需要一次性配置的日期选择器。