我使用Davidwalsh's method来阻塞datepicker日历上的特定日期,但是在我的生产服务器上,数组中的某些日期并没有被阻塞,所以我试图干净地复制代码,并在结果中发现了类似的差异。
This is the JS fiddle
有人能指出我这里遗漏了什么吗?
由于某种原因,11月1日被屏蔽了,而11月4日并没有被屏蔽。
在我的生产服务器的情况下,我们试图在12月份屏蔽两个日期,但它们没有被禁用。从当月开始的日期会被阻止。
任何帮助都将不胜感激!
$(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,''];
}
}
});发布于 2012-11-01 18:20:13
您不能用0填充日期。例如,对于该月的1号:
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/示例
https://stackoverflow.com/questions/13174751
复制相似问题