var range = getDates(new Date(), new Date().addDays(7));
我希望“range”成为一个日期对象的数组,其中包括两个日期之间每一天的日期。关键是它还应该处理月份和年份的边界。var range = getDates(new Date(), new Date().addDays(7));
我希望“range”成为一个日期对象的数组,其中包括两个日期之间每一天的日期。关键是它还应该处理月份和年份的边界。Date.prototype.addDays = function(days) {
var date = new Date(this.valueOf());
date.setDate(date.getDate() + days);
return date;
}
function getDates(startDate, stopDate) {
var dateArray = new Array();
var currentDate = startDate;
while (currentDate <= stopDate) {
dateArray.push(new Date (currentDate));
currentDate = currentDate.addDays(1);
}
return dateArray;
}
以下是一个功能性的演示:http://jsfiddle.net/jfhartsock/cM3ZU/
我查看了上面所有的内容,最终自己写了出来。 你不需要momentjs,一个普通的for循环就足够了,而且使用for循环更有意义,因为for循环是用来计算范围内的值的。
一行代码:
var getDaysArray = function(s,e) {for(var a=[],d=new Date(s);d<=new Date(e);d.setDate(d.getDate()+1)){ a.push(new Date(d));}return a;};
长版本
var getDaysArray = function(start, end) {
for(var arr=[],dt=new Date(start); dt<=new Date(end); dt.setDate(dt.getDate()+1)){
arr.push(new Date(dt));
}
return arr;
};
列出日期之间的时间:
var daylist = getDaysArray(new Date("2018-05-01"),new Date("2018-07-01"));
daylist.map((v)=>v.toISOString().slice(0,10)).join("")
/*
Output:
"2018-05-01
2018-05-02
2018-05-03
...
2018-06-30
2018-07-01"
*/
从过去的日期到现在的天数:
var daylist = getDaysArray(new Date("2018-05-01"),new Date());
daylist.map((v)=>v.toISOString().slice(0,10)).join("")
for (var arr = [], dt = new Date(start), ...)
。;-) - RobGdt<=end
改为dt<=new Date(end)
。 - Srinath Kamath[]
吗?你需要输入日期对象,例如 new Date("2021-03-01")
,而不仅仅是 "2021-03-01"
。比如说,我一开始就忽略了这个。 - jave.web试试这个,记得包含moment js。
function getDates(startDate, stopDate) {
var dateArray = [];
var currentDate = moment(startDate);
var stopDate = moment(stopDate);
while (currentDate <= stopDate) {
dateArray.push( moment(currentDate).format('YYYY-MM-DD') )
currentDate = moment(currentDate).add(1, 'days');
}
return dateArray;
}
var currentDate = moment(startDate);
如果您在相同的moment.js日期上两次使用此方法,您将感到困惑,为什么它只能第一次工作。这是因为javascript通过引用传递对象,所以函数最终会使用两次已经改变的startDate。修补上述修复程序可以确保您在函数范围内使用新的和唯一的moment js对象。请查看此fiddle。 - Adrian MoisagetDates('2021-01-01 23:00:00','2021-01-04 22:00:00')
返回了 ["2021-01-01", "2021-01-02", "2021-01-03"]
,这不包括 2021-01-04
。 - Arun A S我在使用上面的答案时遇到了麻烦,由于本地夏令时(DST)造成的时区变化,日期范围中缺少了某些单日。我实现了一个使用UTC日期的版本来解决这个问题:
function dateRange(startDate, endDate, steps = 1) {
const dateArray = [];
let currentDate = new Date(startDate);
while (currentDate <= new Date(endDate)) {
dateArray.push(new Date(currentDate));
// Use UTC date to prevent problems with time zones and DST
currentDate.setUTCDate(currentDate.getUTCDate() + steps);
}
return dateArray;
}
const dates = dateRange('2020-09-27', '2020-10-28');
console.log(dates);
注意: 时区和夏令时的应用取决于你的locale,一般不建议改写。使用UTC时间可以解决大部分与时间有关的问题。
额外福利: 你可以通过可选的steps
参数来设置要创建时间戳的时间间隔。如果你想设置每周的时间戳,将steps
设置为7
即可。
我使用 moment.js 和 Twix.js,它们为日期和时间的处理提供了非常好的支持。
var itr = moment.twix(new Date('2012-01-15'),new Date('2012-01-20')).iterate("days");
var range=[];
while(itr.hasNext()){
range.push(itr.next().toDate())
}
console.log(range);
我已将它在http://jsfiddle.net/Lkzg1bxb/上运行。
toArray()
而不是iterate()
来简化这个问题:moment.twix(new Date('2012-01-15'),new Date('2012-01-20')).toArray("days");
http://isaaccambron.com/twix.js/docs.html#toarray - Kimeigavar boxingDay = new Date("12/26/2010");
var nextWeek = boxingDay*1 + 7*24*3600*1000;
function getDates( d1, d2 ){
var oneDay = 24*3600*1000;
for (var d=[],ms=d1*1,last=d2*1;ms<last;ms+=oneDay){
d.push( new Date(ms) );
}
return d;
}
getDates( boxingDay, nextWeek ).join("\n");
// Sun Dec 26 2010 00:00:00 GMT-0700 (Mountain Standard Time)
// Mon Dec 27 2010 00:00:00 GMT-0700 (Mountain Standard Time)
// Tue Dec 28 2010 00:00:00 GMT-0700 (Mountain Standard Time)
// Wed Dec 29 2010 00:00:00 GMT-0700 (Mountain Standard Time)
// Thu Dec 30 2010 00:00:00 GMT-0700 (Mountain Standard Time)
// Fri Dec 31 2010 00:00:00 GMT-0700 (Mountain Standard Time)
// Sat Jan 01 2011 00:00:00 GMT-0700 (Mountain Standard Time)
moment-range
,然后这变得非常简单。const Moment = require('moment');
const MomentRange = require('moment-range');
const moment = MomentRange.extendMoment(Moment);
const start = new Date("11/30/2018"), end = new Date("09/30/2019")
const range = moment.range(moment(start), moment(end));
console.log(Array.from(range.by('day')))
moment-range 浏览器示例:
window['moment-range'].extendMoment(moment);
const start = new Date("11/30/2018"), end = new Date("09/30/2019")
const range = moment.range(moment(start), moment(end));
console.log(Array.from(range.by('day')))
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.22.2/moment.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment-range/4.0.1/moment-range.js"></script>
date fns示例:
如果您正在使用date-fns
,那么eachDay
是您的好朋友,您将得到迄今为止最短和最简洁的答案:
console.log(dateFns.eachDay(
new Date(2018, 11, 30),
new Date(2019, 30, 09)
))
<script src="https://cdnjs.cloudflare.com/ajax/libs/date-fns/1.29.0/date_fns.min.js"></script>
function (startDate, endDate, addFn, interval) {
addFn = addFn || Date.prototype.addDays;
interval = interval || 1;
var retVal = [];
var current = new Date(startDate);
while (current <= endDate) {
retVal.push(new Date(current));
current = addFn.call(current, interval);
}
return retVal;
}
function getDates(startDate, endDate, interval) {
const duration = endDate - startDate;
const steps = duration / interval;
return Array.from({length: steps+1}, (v,i) => new Date(startDate.valueOf() + (interval * i)));
}
const startDate = new Date(2017,12,30);
const endDate = new Date(2018,1,3);
const dayInterval = 1000 * 60 * 60 * 24; // 1 day
const halfDayInterval = 1000 * 60 * 60 * 12; // 1/2 day
console.log("Days", getDates(startDate, endDate, dayInterval));
console.log("Half Days", getDates(startDate, endDate, halfDayInterval));
new Date(2017,12,30)
是2018年1月30日,因此日期范围从2018年1月29日开始。在观察夏令时的地区,并不是所有的天数都是8.64e7毫秒(24小时)长的。;-) - RobG我刚刚看到这个问题,最简单的方法是使用moment:
首先需要安装moment和moment-range:
const Moment = require('moment');
const MomentRange = require('moment-range');
const moment = MomentRange.extendMoment(Moment);
const start = moment()
const end = moment().add(2, 'months')
const range = moment.range(start, end)
const arrayOfDates = Array.from(range.by('days'))
console.log(arrayOfDates)
eachDayOfInterval
[1]和addDays
[2]来返回开始日期和结束日期之间的日期数组。 - tinystone