我有一个按如下方式初始化的内联 DatePicker (Week-Picker),它在 Select 上触发一个 ASP.NET 点击事件。它运行良好,我的 ASP 代码确实是它的一部分,但是如果我选择一个日期作为 ex:在通过 DatePicker 的下一个/上一个按钮推进月份之后,当回发后页面刷新时,DatePicker 返回到当前月份......还有它在此处的 selectCurrentWeek() 方法中丢失了选定的 startDate / endDate 范围。
var startDate;
var endDate;
var selectCurrentWeek = function () {
window.setTimeout(function () {
$('.week-picker').find('.ui-datepicker-current-day a').addClass('ui-state-active')
}, 1);
}
$('.week-picker').datepicker({
showOtherMonths: true,
selectOtherMonths: true,
firstDay: 1,
onSelect: function (dateText, inst) {
var date = $(this).datepicker('getDate');
startDate = new Date(date.getFullYear(), date.getMonth(), date.getDate() - date.getDay() + 1);
endDate = new Date(date.getFullYear(), date.getMonth(), date.getDate() - date.getDay() + 6);
var dateFormat = inst.settings.dateFormat || $.datepicker._defaults.dateFormat;
$('#txtDP1').val($.datepicker.formatDate(dateFormat, date, inst.settings));
selectCurrentWeek();
DP1_Submit();
},
beforeShowDay: function (date) {
var cssClass = '';
if (date >= startDate && date <= endDate)
cssClass = 'ui-datepicker-current-day';
return [true, cssClass];
},
onChangeMonthYear: function (year, month, inst) {
selectCurrentWeek();
}
});
$('.week-picker .ui-datepicker-calendar tr').live('mousemove', function () { $(this).find('td a').addClass('ui-state-hover'); });
$('.week-picker .ui-datepicker-calendar tr').live('mouseleave', function () { $(this).find('td a').removeClass('ui-state-hover'); });
隐藏的字段/按钮是:
<asp:TextBox ID="txtDP1" runat="server" style="display:none;" />
<asp:Button ID="btnDP1" runat="server" Text="Go" style="display:none;" />
我尝试使用 setDate() 方法和 defaultDate 属性但没有成功。帮助?