Jquery UI Datepicker beforeShowDay阻塞日期数组的bug

时间:2012-11-01 10:04:24

标签: jquery jquery-ui datepicker

我正在使用Davidwalsh's method来阻止datepicker日历上的特定日期,但是在我的生产服务器上,数组中的某些日期没有被阻止,所以我尝试对代码进行干净的复制,并发现结果中的类似差异。

This is the JS fiddle

有人可以指出我在这里缺少的东西吗?

出于某种原因,11月1日被阻止,第4个nov没有被阻挡。

在我的生产服务器的情况下,我们试图阻止12月份的2个日期,但是它们未能被禁用。本月的日期被阻止了。

非常感谢任何帮助!

$(document).ready(function(){

        var cdates = new Array();
        cdates = ['2012-11-04','2012-11-12','2012-12-03','2012-12-12','2012-12-18','2012-12-20'];

        $('.datepicker').datepicker({
            beforeShowDay: check_closed
        }); 

        function check_closed(date)
        {               var m = date.getMonth(), d = date.getDate(), y = date.getFullYear();

            for (i = 0; i < cdates.length; i++) {
                if($.inArray(y + '-' + (m+1) + '-' + d,cdates) != -1 || new Date() > date) {
                    console.log('bad:  ' + (m+1) + '-' + d + '-' + y + ' / ' + cdates[i]);
                  return [false,''];
                }
                    console.log('good:  ' + (m+1) + '-' + d + '-' + y);
                return [true,''];    
            }                
        }
    });​

1 个答案:

答案 0 :(得分:1)

你不是用0填充日期。例如,对于本月的第一天:

d = date.getDate(); // => 1 and for adequate comparison needs to be 01

解决方案:

d = date.getDate();
if( d < 10 ) { d = "0" + d; }

这就是为什么11月4日没有禁用,因为var m =“2012-11-4”并且数组中唯一存在的值是“2012-11-04。

以下是一个工作示例http://jsfiddle.net/bruno/KYzaR/8/