2017-04-27 55 views
1

当我在下拉菜单中选择“过去24小时”时,我有一个下拉菜单(值为“过去24小时”,“过去48小时”等) 我需要从现在到昨天的所有日期,每隔一小时。获取24小时日期和时间循环在javascript中

我试图此,

var todayDate = new Date(); 
    if(type=="hours"){ // for hours based drop-down 
     var oneDayAgo = new Date(todayDate.getTime()); 
     oneDayAgo.setDate(todayDate.getDate() - 1); 
     console.log("oneDayAgo"+oneDayAgo); 
     var hours = todayDate.getHours(); 
     for(var i = hours; i <= hours+24; i++) { 
      if(i<25){ 
       var newHours=i; 
       var newDates=todayDate.getFullYear() + "-" + ("00" + (todayDate.getMonth() + 1)).slice(-2) + "-" + ("00" + todayDate.getDate()).slice(-2) + " " + ("00" +newHours).slice(-2) + ":" + ("00" + todayDate.getMinutes()).slice(-2) + ":" + ("00" + todayDate.getSeconds()).slice(-2); 
       console.log(newDates); 
      }else{ 
       var newHours=i-24; 
       var newDates=oneDayAgo.getFullYear() + "-" + ("00" + (oneDayAgo.getMonth() + 1)).slice(-2) + "-" + ("00" + oneDayAgo.getDate()).slice(-2) + " " + ("00" +newHours).slice(-2) + ":" + ("00" + oneDayAgo.getMinutes()).slice(-2) + ":" + ("00" + oneDayAgo.getSeconds()).slice(-2); 
       console.log(newDates); 
      } 
     } 
    } 

我的期望输出是,

例如当前日期和时间是2014年4月27日13点07分的装置,

输出像2014-04 -27 13:07,2014-04-27 12:07,2014-04-27 11:07,2014-04-27 10:07 .... 2014-04-26 13:07

please help在这。谢谢

+0

避免在循环中创建变量。之前创建它们并在里面使用它们。 – franckstifler

回答

0

function getDateItems(hours) { 
 
    var toDate = new Date(); 
 
    var fromDate = new Date(); 
 
    fromDate.setTime(fromDate.getTime() - (hours * 60 * 60 * 1000)); 
 
    var result = []; 
 
    
 
    while (toDate >= fromDate) { 
 
    result.push(toDate.getFullYear() + "-" + ("00" + (toDate.getMonth() + 1)).slice(-2) + "-" + ("00" + toDate.getDate()).slice(-2) + " " + ("00" + toDate.getHours()).slice(-2) + ":" + ("00" + toDate.getMinutes()).slice(-2) + ":" + ("00" + toDate.getSeconds()).slice(-2)); 
 
    // consider using moment.js library to format date 
 
    
 
    toDate.setTime(toDate.getTime() - (1 * 60 * 60 * 1000)); 
 
    } 
 

 
    return result; 
 
} 
 

 
var datesFrom24Hours = getDateItems(24); 
 
var datesFrom48Hours = getDateItems(48); 
 

 
console.log(datesFrom24Hours);

+0

谢谢..其工作符合我的期望 – user3265033

0

这里有一个working sample,这可能是你想要的。

//get type and hoursOption from dropdowns 
var type = 'hours' 
var hoursOption = 48; 

var todayDate = new Date(); 

if(type=="hours"){ // for hours based drop-down 

    var hours = todayDate.getHours(); 
    for(var i = hours; i <= hours + hoursOption; i++) { 
      todayDate.setHours(todayDate.getHours() - 1) 
     var newDates = todayDate.getFullYear() + "-" + ("00" + (todayDate.getMonth() + 1)).slice(-2) + "-" + ("00" + todayDate.getDate()).slice(-2) + " " + ("00" + todayDate.getHours()).slice(-2) + ":" + ("00" + todayDate.getMinutes()).slice(-2) + ":" + ("00" + todayDate.getSeconds()).slice(-2); 
      console.log(newDates); 

    } 
} 

for-loop对于可变hours我加入hourOption它来自下拉选项,例如。 24,48,72等

内部循环你采取todayDate,只是比以前少加一个小时,所以它会显示小时倒数。