我正在使用内联日期选择器,突出显示包含事件的日期。每次月份更改时,都必须从服务器加载新事件。问题是,onChangeMonthYear仅在与当月不同的月份触发。例如,如果是八月,它会在前几个月(7月,6月,可能......)以及随后的所有月份(9月,10月......)发射,但不会在我改回到8月时触发。这是我的代码:
function highlightDates(date) {
for ( var i = 0; i < agenda.length; i++) {
var start = agenda[i].start.toShortDate();
var end = agenda[i].end.toShortDate();
if (start >= date && end <= date) {
return [ true, 'dateHasEvent' ];
}
}
return [ true, '' ];
}
Date.prototype.toShortDate = function() {
var date = new Date(this.getFullYear(), this.getMonth(), this.getDate());
return date;
};
function monthChanged(year, month, instance) {
var date = new Date(year, month - 1);
$.getJSON('json.do', {
time : date.getTime()
}, updateCalendars);
}
function updateCalendars(data, status) {
agenda = data;
$('#calendar').datepicker('refresh');
}
var agenda = [];
$(function() {
$('#calendar').datepicker( {
beforeShowDay : highlightDates,
onChangeMonthYear : monthChanged,
changeMonth : false,
changeYear : false,
showButtonPanel : false
});
});
有人知道这是错误还是预期的行为?
答案 0 :(得分:0)
嗯,这对我来说是愚蠢的。问题是getJSON方法。关于json接受什么,显然非常挑剔。所以在我制作了正确的json后,一切都按原样运行。