jQuery datepicker语言 - 如何覆盖初始化



我在我的项目中使用了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)
        });
    });

问题是第二个代码块(带有minDatemaxDate)永远不会被"执行"——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)
        });
    });

另一种选择(如您所提到的)是挑选那些需要一次性配置的日期选择器。

最新更新