日期范围之间的Javascript循环

时间:2010-12-03 11:24:44

标签: javascript date loops

给定两个Date()对象,其中一个小于另一个,我如何在日期之间每天循环?

for(loopDate = startDate; loopDate < endDate; loopDate += 1)
{

}

这种循环会起作用吗?但是如何在循环计数器中添加一天?

谢谢!

10 个答案:

答案 0 :(得分:156)

这是一种方法,通过使用添加一天的方式使得日期在必要时滚动到下个月,并且不会乱解毫秒。夏令时也不是问题。

var now = new Date();
var daysOfYear = [];
for (var d = new Date(2012, 0, 1); d <= now; d.setDate(d.getDate() + 1)) {
    daysOfYear.push(new Date(d));
}

请注意,如果您想存储日期,则需要制作一个新日期(如上所述new Date(d)),否则您最终会将每个存储日期作为最终日期循环中d的值。

答案 1 :(得分:64)

根据汤姆古伦的回答。

var start = new Date("02/05/2013");
var end = new Date("02/10/2013");


var loop = new Date(start);
while(loop <= end){
   alert(loop);           

   var newDate = loop.setDate(loop.getDate() + 1);
   loop = new Date(newDate);
}

答案 2 :(得分:8)

如果startDate和endDate确实是日期对象,你可以将它们转换为自1970年1月1日午夜以来的毫秒数,如下所示:

var startTime = startDate.getTime(), endTime = endDate.getTime();

然后你可以从一个循环到另一个循环增加loopTime 86400000(1000 * 60 * 60 * 24) - 一天内的毫秒数:

for(loopTime = startTime; loopTime < endTime; loopTime += 86400000)
{
    var loopDay=new Date(loopTime)
    //use loopDay as you wish
}

答案 3 :(得分:6)

如果你允许自己使用Moment.js

,我想我找到了一个更简单的答案

&#13;
&#13;
// cycle through last five days, today included
// you could also cycle through any dates you want, mostly for
// making this snippet not time aware
const currentMoment = moment().subtract(4, 'days');
const endMoment = moment().add(1, 'days');
while (currentMoment.isBefore(endMoment, 'day')) {
  console.log(`Loop at ${currentMoment.format('YYYY-MM-DD')}`);
  currentMoment.add(1, 'days');
}
&#13;
<script src="https://cdn.jsdelivr.net/npm/moment@2/moment.min.js"></script>
&#13;
&#13;
&#13;

答案 4 :(得分:3)

这里简单的工作代码,为我工作

var from = new Date(2012,0,1);
var to = new Date(2012,1,20);
    
// loop for every day
for (var day = from; day <= to; day.setDate(day.getDate() + 1)) {
      
   // your day is here

}

答案 5 :(得分:1)

var start = new Date("2014-05-01"); //yyyy-mm-dd
var end = new Date("2014-05-05"); //yyyy-mm-dd

while(start <= end){

    var mm = ((start.getMonth()+1)>=10)?(start.getMonth()+1):'0'+(start.getMonth()+1);
    var dd = ((start.getDate())>=10)? (start.getDate()) : '0' + (start.getDate());
    var yyyy = start.getFullYear();
    var date = dd+"/"+mm+"/"+yyyy; //yyyy-mm-dd

    alert(date); 

    start = new Date(start.setDate(start.getDate() + 1)); //date increase by 1
}

答案 6 :(得分:0)

基于Tabare的答案, 我不得不在最后添加一天,因为在

之前切断了周期
var start = new Date("02/05/2013");
var end = new Date("02/10/2013");
var newend = end.setDate(end.getDate()+1);
var end = new Date(newend);
while(start < end){
   alert(start);           

   var newDate = start.setDate(start.getDate() + 1);
   start = new Date(newDate);
}

答案 7 :(得分:0)

如果您想以毫秒为单位的高效方法:

var daysOfYear = [];
for (var d = begin; d <= end; d = d + 86400000) {
    daysOfYear.push(new Date(d));
}

答案 8 :(得分:0)

让我们假设您从UI获取了开始日期和结束日期,并将其存储在控制器中的作用域变量中。

然后声明一个数组,该数组将在每次函数调用时重置,以便在下一次函数调用时可以存储新数据。

var dayLabel = [];

请记住使用新日期(您的起始变量),因为如果您不使用新日期并将其直接分配给变量,则setDate函数将在每次迭代中更改原始变量值。

for (var d = new Date($scope.startDate); d <= $scope.endDate; d.setDate(d.getDate() + 1)) {
                dayLabel.push(new Date(d));
            }

答案 9 :(得分:-3)

根据Jayarjo的回答:

var loopDate = new Date();
loopDate.setTime(datFrom.valueOf());

while (loopDate.valueOf() < datTo.valueOf() + 86400000) {

    alert(loopDay);

    loopDate.setTime(loopDate.valueOf() + 86400000);
}