我有一个问题。
我有一系列数据范围:
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'];
我开始用一个循环来做这个问题,但当月份跳到另一个时,问题就出现了吗?
答案 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开始!
答案 3 :(得分:-1)
月检查......如果月份= [1,3,5,6,7,8,10,12]不得超过31天,依此类推......