1

我想要一个日期选择器,用户只能从日期选择器中选择月份和年份,并且我还需要使用从上一个日期选择器中选择的月份和年份来限制下一个日期选择器。

谁能帮我吗?

4

4 回答 4

2

肖恩的回答非常好,如果你也想禁用日期选择,你可以使用不同的方法,你可以在这个小提琴中看到结果:

日历是隐藏的,所以你只能选择月份和年份。在第一个日期选择器中选择日期时,第二个日期选择器的 minDate 正在适应。

编辑

当 dateformat 不提供日期时,jQuery datepicker 会出现严重问题。我更改了代码以使其工作。唯一的问题是在打开日期选择器时,我必须将日期转换为合适的格式。看看新的小提琴。

HTML:

<p>Date: <input type="text" id="first-datepicker"/></p>
<p>Date: <input type="text" id="second-datepicker"/></p>

CSS:

#ui-datepicker-div .ui-datepicker-calendar,
#ui-datepicker-div .ui-datepicker-current
{
    display: none !important;
}

JAVASCRIPT:

$('#first-datepicker').datepicker({
    changeYear: true,
    changeMonth: true,
    beforeShow: function (input, inst) {
        setMyDate(inst);
    },
    onClose: function (dateText, inst) {
        saveMyDate(inst);

        var secondDatePicker = $('#second-datepicker').data('datepicker');
        var dateSetted = secondDatePicker.input.data('date-setted');

        setMyDate(secondDatePicker);

        secondDatePicker.input.datepicker('option', 'minDate', new Date(inst.selectedYear, inst.selectedMonth, 0));     

        if (dateSetted == true) {
            saveMyDate(secondDatePicker);
        };
    }
});

$('#second-datepicker').datepicker({
    changeYear: true,
    changeMonth: true,
    beforeShow: function (input, inst) {
        setMyDate(inst);
    },
    onClose: function (dateText, inst) {
        saveMyDate(inst);
    }
});

function saveMyDate(inst) {
    inst.selectedDay = 1;
    inst.input.data('year', inst.selectedYear);
    inst.input.data('month', inst.selectedMonth);
    inst.input.data('day', inst.selectedDay );

    var date = new Date(inst.selectedYear, inst.selectedMonth, inst.selectedDay);
    inst.input.datepicker('setDate', date );
    formatDate(inst, date);
    inst.input.data('date-setted', true);
};

function setMyDate(inst) {
    var dateSetted = inst.input.data('date-setted');

    if (dateSetted == true) {
        var year = inst.input.data('year');
        var month = inst.input.data('month');
        var day = inst.input.data('day');

        var date = new Date(year, month, day);
        inst.input.datepicker('setDate', date );
    };
};

function formatDate(inst, date) {
    var formattedDate = $.datepicker.formatDate('MM - yy', date);
inst.input.val(formattedDate);
};
于 2012-12-03T11:28:13.693 回答
1

您可以使用这个monthpicker jquery 小部件:https ://github.com/lucianocosta/jquery.mtz.monthpicker

于 2012-12-03T11:02:03.363 回答
1

您可以修改 jQuery datepicker 以仅允许用户选择某些日期,在这种情况下,我们可以将其限制为每月的第一天:

$(".datepicker").datepicker({
    beforeShowDay: disableDaysExceptFirst
})

function disableDaysExceptFirst(date) {
    if (date.getDate() != 1) {
        return [false, date.getDate().toString() + "_day"];
    }
    return [true, ""];
}

您还可以修改选项以不同方式显示日期:

$(".datepicker").datepicker({
    dateFormat: 'mm/yy'
});

将两者结合起来,我们得到:

$(".datepicker").datepicker({
    beforeShowDay: disableDaysExceptFirst,
    dateFormat: 'mm/yy'
})

function disableDaysExceptFirst(date) {
    if (date.getDate() != 1) {
        return [false, date.getDate().toString() + "_day"];
    }
    return [true, ""];
}

您还可以使用它来限制您的第二个日期选择器:

var restrictedMonth = parseInt($("#myFirstDatePicker").text().split("/")[0]); //replace myFirstDatePicker with the HTML ID of the text input your datepicker is attached to

$("#myFirstDatePicker").datepicker({
    beforeShowDay: disableAllExceptCurrentMonth,
    dateFormat: 'dd/mm/yy' //swap mm and dd for US dates
});

function disableAllExceptCurrentMonth(date) {
    if (date.getMonth() != restrictedMonth) {
        return [false, date.getDate().toString() + "_day"];
    }
    return [true, ""];
}
于 2012-12-03T11:13:25.417 回答
0

如果您可以在 html5 中工作,我建议您对较新的浏览器使用新月份的输入支持

只需使用并让魔法发生。

https://developer.mozilla.org/fr/docs/Web/HTML/Element/Input/month

于 2018-06-13T13:37:31.567 回答