即使在刷新后也要记住日期选择器中选择的日期


Remember the date selected in datepicker even after refresh

我只想知道我的日期选择器如何记住选择了哪个月。例如,我选择2013年6月1日,即使在刷新后,日期选择器中显示的月份仍然是6月。

这是我的密码。

$(function() {
    
    var startDate;
    var endDate;
    var selectCurrentWeek = function() {
        window.setTimeout(function () {
            $('#weekpicker').datepicker('widget').find('.ui-datepicker-current-day a').addClass('ui-state-active')
        }, 1);
    }
    
    $('#weekpicker').datepicker( {
        
        changeYear:true,
        changeMonth:true,
        showButtonPanel:true,
        
        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() + 7);
            var dateFormat = inst.settings.dateFormat || $.datepicker._defaults.dateFormat;
            $('#weekpicker').val($.datepicker.formatDate( dateFormat, startDate, inst.settings )
                 + ' - ' + $.datepicker.formatDate( dateFormat, endDate, inst.settings ));
            
         selectCurrentWeek();   
     
        },
        
        beforeShow: function() {
            selectCurrentWeek();
        },
        
        beforeShowDay: function(date) {
            var cssClass = '';
            if(date >= startDate && date <= endDate)
                cssClass = 'ui-datepicker-current-day';
            return [true, cssClass];
        },
        
        onChangeMonthYear: function(year, month, inst) {
            selectCurrentWeek(); 
        }
    
    }).datepicker('widget').addClass('ui-weekpicker');
    
    $('.ui-weekpicker .ui-datepicker-calendar tr').live('mousemove', function() { $(this).find('td a').addClass('ui-state-hover'); });
    $('.ui-weekpicker .ui-datepicker-calendar tr').live('mouseleave', function() { $(this).find('td a').removeClass('ui-state-hover'); });
    
});

您需要处理会话。

网站刷新后,只需将日期添加到PHP会话中即可。你可以在这里阅读更多关于sessions的内容,也可以在这里找到一个更具体的例子。

好吧,您在if语句中为"添加了一个空格。无论如何,我想我的逻辑不好——你可能应该用"&&"而不是"||"。因此,请按原样使用以下代码:

$('input[type=text][id*=myDate1]').datepicker({
                showOn: "button",
                buttonImage: "/Images/cal.gif",
                buttonImageOnly: true,
                onSelect: function (dateText, inst) {    $('#HiddenField1').val(dateText) },
                changeMonth: true,
                changeYear: true,
                showWeek: true,
                firstDay: 1
            });
            var theDate;
            if ($('#HiddenField1').val() != "" && $('#HiddenField1').val() != null) {
                theDate = $('#HiddenField1').val();
            }
            else {
                theDate = new Date();
            }
            alert(theDate);
            $('input[type=text][id*=myDate1]').datepicker("option", "showAnim", 'bounce');
            $('input[type=text][id*=myDate1]').datepicker("option", "dateFormat", 'dd/mm/yy');
            $('input[type=text][id*=myDate1]').datepicker("option", "altFormat", 'dd/mm/yy');
            $('input[type=text][id*=myDate1]').datepicker('setDate', theDate);