将日期范围转换为包含所有日期的数组

时间:2013-03-27 12:57:46

标签: javascript datetime

我有一个问题。

我有一系列数据范围:

var range_date_off=['31/03/2013','03/04/2013'];

我需要将其转换为:

var dates_off=['31/03/2013','01/04/2013','02/04/2013','03/04/2013'];

我开始用一个循环来做这个问题,但当月份跳到另一个时,问题就出现了吗?

4 个答案:

答案 0 :(得分:3)

我在这里使用date.js

range = ['31/03/2013','03/04/2013']

begin = Date.parseExact(range[0], 'dd/MM/yyyy')
end   = Date.parseExact(range[1], 'dd/MM/yyyy')

dates = []

while(begin <= end) {
    dates.push(begin.toString("dd/MM/yyyy"))
    begin.addDays(1)
}

结果:

["31/03/2013", "01/04/2013", "02/04/2013", "03/04/2013"]

答案 1 :(得分:3)

这是使用正则表达式解析日期

var range_date_off=['31/03/2013','03/04/2013'];
var d1 = parseDate(range_date_off[0])
var d2= parseDate(range_date_off[1])

var days= [];
for (var dt = d1; dt <= d2; dt.setDate(dt.getDate() + 1)) {
    var fdt = new Date(dt)
    days.push ( fdt.getDate() + "/" + (fdt.getMonth() + 1) + "/" + fdt.getFullYear());
}

function parseDate(input) {
  var parts = input.match(/(\d+)/g);
  return new Date(parts[2], parts[1]-1, parts[0]); 
}

答案 2 :(得分:1)

您可以使用UTC算法执行此操作:

var start = Date.UTC(2013, 2, 31);
var end = Date.UTC(2013, 3, 3);
var currDate = start;
var dates = [];
while (currDate <= end) {
    var d = new Date(currDate);
    dates.push((d.getDate() + "/" + (d.getMonth() + 1) + "/" + d.getFullYear()));
   currDate += (1000 * 60 * 60 * 24);
}

注意,javascript月份从0开始!

http://jsfiddle.net/hKxzw/

答案 3 :(得分:-1)

月检查......如果月份= [1,3,5,6,7,8,10,12]不得超过31天,依此类推......