jQuery datepicker 日期数组禁用日期不正确
jQuery datepicker date array disable dates incorrect
我正在尝试禁用从数组返回的日期,问题是禁用的日期顺序不正确,1 月的日期显示在 2 月,2 月的日期显示在 3 月,而 3 月根本没有显示为每张图片
代码如下
<script>
$(function () {
var bDates = [{ start: new Date(2019, 01, 06), end: new Date(2019, 01, 17) },
{ start: new Date(2019, 02, 05), end: new Date(2019, 02, 07) },
{ start: new Date(2019, 03, 07), end: new Date(2019, 03, 10) }];
var dateFormat = 'yyyy mm dd',
from = $( "#from" ).datepicker({
defaultDate: "+1w",
changeMonth: true,
numberOfMonths: 3,
minDate:0,
beforeShowDay: function(date) {
for (var i = 0; i < bDates.length; i++) {
if (date >= bDates[i].start && date <= bDates[i].end) return [false, ''];
}
return [true, ''];
}
})
.on( "change", function() {
to.datepicker( "option", "minDate", getDate( this ) );
}),
to = $( "#to" ).datepicker({
defaultDate: "+1w",
changeMonth: true,
numberOfMonths: 3
})
.on( "change", function() {
from.datepicker( "option", "maxDate", getDate( this ) );
});
} );
</script>
谁能发现我做错了什么
您构建的日期有误。见 Date constructor's parameters:
The argument monthIndex is 0-based. This means that January = 0 and
December = 11.
您的代码变为(仅更改了日期构造函数):
$(function() {
var bDates = [{
start: new Date(2019, 0, 10),
end: new Date(2019, 0, 17)
},
{
start: new Date(2019, 1, 5),
end: new Date(2019, 1, 7)
},
{
start: new Date(2019, 2, 7),
end: new Date(2019, 2, 10)
}
];
var dateFormat = 'yyyy mm dd',
from = $("#from").datepicker({
defaultDate: "+1w",
changeMonth: true,
numberOfMonths: 3,
minDate: 0,
beforeShowDay: function(date) {
for (var i = 0; i < bDates.length; i++) {
if (date >= bDates[i].start && date <= bDates[i].end) return [false, ''];
}
return [true, ''];
}
})
.on("change", function() {
to.datepicker("option", "minDate", getDate(this));
}),
to = $("#to").datepicker({
defaultDate: "+1w",
changeMonth: true,
numberOfMonths: 3
})
.on("change", function() {
from.datepicker("option", "maxDate", getDate(this));
});
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.js"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.css" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-datetimepicker/2.5.20/jquery.datetimepicker.js"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/jquery-datetimepicker/2.5.20/jquery.datetimepicker.min.css" />
<input id="from" />
<input id="to" />
我正在尝试禁用从数组返回的日期,问题是禁用的日期顺序不正确,1 月的日期显示在 2 月,2 月的日期显示在 3 月,而 3 月根本没有显示为每张图片
代码如下
<script>
$(function () {
var bDates = [{ start: new Date(2019, 01, 06), end: new Date(2019, 01, 17) },
{ start: new Date(2019, 02, 05), end: new Date(2019, 02, 07) },
{ start: new Date(2019, 03, 07), end: new Date(2019, 03, 10) }];
var dateFormat = 'yyyy mm dd',
from = $( "#from" ).datepicker({
defaultDate: "+1w",
changeMonth: true,
numberOfMonths: 3,
minDate:0,
beforeShowDay: function(date) {
for (var i = 0; i < bDates.length; i++) {
if (date >= bDates[i].start && date <= bDates[i].end) return [false, ''];
}
return [true, ''];
}
})
.on( "change", function() {
to.datepicker( "option", "minDate", getDate( this ) );
}),
to = $( "#to" ).datepicker({
defaultDate: "+1w",
changeMonth: true,
numberOfMonths: 3
})
.on( "change", function() {
from.datepicker( "option", "maxDate", getDate( this ) );
});
} );
</script>
谁能发现我做错了什么
您构建的日期有误。见 Date constructor's parameters:
The argument monthIndex is 0-based. This means that January = 0 and December = 11.
您的代码变为(仅更改了日期构造函数):
$(function() {
var bDates = [{
start: new Date(2019, 0, 10),
end: new Date(2019, 0, 17)
},
{
start: new Date(2019, 1, 5),
end: new Date(2019, 1, 7)
},
{
start: new Date(2019, 2, 7),
end: new Date(2019, 2, 10)
}
];
var dateFormat = 'yyyy mm dd',
from = $("#from").datepicker({
defaultDate: "+1w",
changeMonth: true,
numberOfMonths: 3,
minDate: 0,
beforeShowDay: function(date) {
for (var i = 0; i < bDates.length; i++) {
if (date >= bDates[i].start && date <= bDates[i].end) return [false, ''];
}
return [true, ''];
}
})
.on("change", function() {
to.datepicker("option", "minDate", getDate(this));
}),
to = $("#to").datepicker({
defaultDate: "+1w",
changeMonth: true,
numberOfMonths: 3
})
.on("change", function() {
from.datepicker("option", "maxDate", getDate(this));
});
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.js"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.css" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-datetimepicker/2.5.20/jquery.datetimepicker.js"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/jquery-datetimepicker/2.5.20/jquery.datetimepicker.min.css" />
<input id="from" />
<input id="to" />