0

我只想知道我的日期选择器是否能记住选择的月份。例如,我选择 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'); });

    
});
4

2 回答 2

0

好吧,您在 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);
于 2015-04-15T11:03:09.823 回答
0

您将需要处理会话。

刷新网站后,只需将日期添加到PHP 会话中。您可以在此处阅读有关 sessionn的更多信息,并在此处阅读有关您正在寻找的内容的更具体示例

于 2013-07-10T09:13:49.547 回答