0

我想禁用除 start_date 和 end_date 范围之外的所有日期,例如:日期从 26/05/2015 到 29/05/2015,因此开始之前和结束之后的所有日期都被禁用。为此,我使用pickadate 和pickadate 月份索引从零开始。

$('.datepicker2').pickadate({
        format: 'dd/md/yyyy',
        selectMonths: true,
        selectYears: 25,
min: [$("#leave_start_date").val().split("/").map(Number).reverse()],
max: [$("#leave_end_date").val().split("/").map(Number).reverse()]
});

但它不工作。它禁用剩余当前日期的所有日期。请指导我如何解决这个问题。我只想禁用那些不在 start_date 和 end_date 值范围内的日期。

4

1 回答 1

2

我认为第一个问题是minand的值max可以采用类似的数组,[2014,05,26]但是这样map,我怀疑您发送的是嵌套在数组中的数组[[2014,05,26]]

'15/05/2015'.split('/').map(Number)
JS> [15, 5, 2015]
'15/05/2015'.split('/').map(Number).reverse()
JS> [2015, 5, 15]  <<<<< this is what (i think) pickadate wants
['15/05/2015'.split('/').map(Number).reverse()]
JS> [Array[3]]    <<<<< this is what (i think) you are sending

另外,正如您在标题中提到的,pickadate期望的月份计数器从 0 开始。使用这样的小辅助函数

function formatDateForPickadate(date_string) {
  vals = date_string.split('/').map(Number).reverse()
  vals[1] -= 1
  return vals
}

你可以做:

min: formatDateForPickadate($("#leave_start_date").val()),
max: formatDateForPickadate($("#leave_end_date").val())

并且偏移月份将得到正确修复。

于 2015-05-26T06:26:49.487 回答