gpt4 book ai didi

jquery UI 日期选择器 : calculate minDate x years from today

转载 作者:行者123 更新时间:2023-12-01 08:36:00 26 4
gpt4 key购买 nike

下午好

我正在尝试为 jQuery UI 日期选择器设置 minDate,这应该对 12 到 17 岁之间的所有用户有效。仅使用 maxDate 就可以正常工作。我知道我必须以某种方式计算 minDate 。我搜索了所有其他 StackOverflow 线程,但未能找到类似的内容。我找到的其他解决方案设置了固定日期,但与今天相比,我总是需要 12-17 年。

到目前为止我已经尝试过:

minDate: new Date((currentYear - 12), currentMonth, currentDay))

minDate: "-12y"

我当前的示例:

$(".datepicker").datepicker({
numberOfMonths: 1,
firstDay: 1,
defaultDate: 0,
changeMonth: true,
changeYear: true,
yearRange: '1910:c',
dateFormat: 'dd.mm.yy',
beforeShow: function () {
var currentYear = (new Date).getFullYear();
var currentMonth = (new Date).getMonth() + 1;
var currentDay = (new Date).getDate();

$(this).datepicker({
minDate: new Date((currentYear - 12), currentMonth, currentDay),
maxDate: "-17y -11m -30d"
});
}
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script src="https://code.jquery.com/ui/1.12.1/jquery-ui.min.js"></script>
<link href="https://code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css" rel="stylesheet"/>

<input type="text" class="datepicker" id="myDate">

最佳答案

minDate: "-12y" 工作得很好,但是如果您只想允许 12 到 17 岁之间的年龄,则需要同时使用 minDatemaxDate 设置允许的范围。

因此,您对 onBeforeShow() 的使用以及 numberOfMonthsdefaultDateyearRange 都是多余的。试试这个:

$(".datepicker").datepicker({
firstDay: 1,
changeMonth: true,
changeYear: true,
dateFormat: 'dd.mm.yy',
minDate: '-17y', // min 17 years ago
maxDate: '-12y', // max 12 years ago
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script src="https://code.jquery.com/ui/1.12.1/jquery-ui.min.js"></script>
<link href="https://code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css" rel="stylesheet" />

<input type="text" class="datepicker" id="myDate">

关于jquery UI 日期选择器 : calculate minDate x years from today,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55266364/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com