记住即使在刷新后在datepicker中选择的日期

时间:2013-07-10 09:10:24

标签: php javascript jquery codeigniter

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


});

感谢高级!!!

2 个答案:

答案 0 :(得分:0)

您需要处理会话。

刷新网站后,只需将日期添加到PHP session即可。 您可以阅读有关会话here的更多信息以及您正在寻找的更具体的示例here

答案 1 :(得分:0)

嗯,你为&#34;&#34;添加了一个空格。在if语句中。而且我想我的逻辑很糟糕 - 你应该使用&#34;&amp;&amp;&#34;而不是&#34; ||&#34;。因此,请完全按照以下代码使用:

$('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);