JavaScript生成指定范圍的時(shí)間列表
遇到一個(gè)場(chǎng)景,需要拿到指定時(shí)間范圍內(nèi)的每一天,滿足格式"YYYYMMDD",簡(jiǎn)單的功能,簡(jiǎn)單的思路
準(zhǔn)備
date對(duì)象有很多的方法,用到了以下:
new date ()生成date對(duì)象,可以直接指定年月日等,new date(year,month,day)
getFullYear() 返回date對(duì)象中的年份
getMonth() 返回date對(duì)象中的月份(0~11),注意從0開始計(jì)
getDate() 返回date對(duì)象中的天,注意從 1 開始計(jì)
getTime() 返回1970年1月1日到date對(duì)象的毫秒數(shù)
解析指定范圍
規(guī)定按照 yyyy-mm-dd格式字符串輸入時(shí)間范圍,split分割即可得到開始和結(jié)束時(shí)間的年月日,再生成對(duì)應(yīng)的date對(duì)象,拿到毫秒數(shù)
let st = start.split('-');
let et = end.split('-');
let startTime = new Date(st[0],st[1]-1,st[2]).getTime();
let endTime = new Date(et[0],et[1]-1,et[2]).getTime();
注意 : 月份需要減 1 ,因?yàn)槭菑?開始計(jì)的
拿到每一天
如何知道時(shí)間范圍內(nèi)有那些天呢?上面有了開始和結(jié)束時(shí)間距離1970.1.1的毫秒數(shù),每一天有24 * 60 * 60 * 1000的毫秒數(shù),所以我們可以通過毫秒數(shù)計(jì)算出每一天
for( let i = startTime ; i <= endTime ; ){
res.push(formatTime(i,''));
i += 24 * 60 * 60 * 1000;
}
格式化輸出
將時(shí)間格式化,個(gè)位數(shù)字補(bǔ)0,加上指定的分割符
function formatTime(time,spliter = '-'){
let date = new Date(time);
let year = date.getFullYear();
let month = (date.getMonth() + 1) >= 10 ? (date.getMonth() + 1) : '0' + (date.getMonth() + 1);
let day = date.getDate() >= 10 ? date.getDate() : '0' + date.getDate();
return `${year}${spliter}${month}${spliter}${day}
}
驗(yàn)證
總結(jié)
以上所述是小編給大家介紹的JavaScript生成指定范圍的時(shí)間列表,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
JavaScript獲取網(wǎng)頁中第一個(gè)圖片id的方法
這篇文章主要介紹了JavaScript獲取網(wǎng)頁中第一個(gè)圖片id的方法,涉及javascript中document.images方法的使用技巧,需要的朋友可以參考下2015-04-04
JS+CSS實(shí)現(xiàn)帶小三角指引的滑動(dòng)門效果
這篇文章主要介紹了JS+CSS實(shí)現(xiàn)帶小三角指引的滑動(dòng)門效果,可實(shí)現(xiàn)帶有箭頭提示效果的滑動(dòng)門功能,涉及JavaScript動(dòng)態(tài)操作頁面元素樣式的相關(guān)技巧,需要的朋友可以參考下2015-09-09
Javascript 顏色漸變效果的實(shí)現(xiàn)代碼
在搭建博主博客的時(shí)候,尋思著做一些效果,看到菜單,就想是不是可以做一下顏色的漸變,增加一點(diǎn)動(dòng)態(tài)的感覺。有個(gè)jquery的插件,效果相當(dāng)不錯(cuò),不過博主還是打算自立更生寫一下,看看能不能實(shí)現(xiàn)2013-10-10
JavaScript驗(yàn)證一個(gè)url的方法總結(jié)
最近遇到幾次需要校驗(yàn)URL的,使用這篇文章小編就為大家整理了一下幾個(gè)JavaScript校驗(yàn)URL的方法,文中的示例代碼簡(jiǎn)潔易懂,感興趣的小伙伴可以了解一下2023-12-12
【經(jīng)驗(yàn)總結(jié)】編寫JavaScript代碼時(shí)應(yīng)遵循的14條規(guī)律
這篇文章主要介紹了編寫JavaScript代碼時(shí)應(yīng)遵循的14條規(guī)律,涉及javascript變量的定義,函數(shù)、表單、json的使用,邏輯運(yùn)算與頁面元素操作技巧等,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2016-06-06
原生 JS Ajax,GET和POST 請(qǐng)求實(shí)例代碼
這篇文章主要介紹了原生 JS Ajax,GET和POST 請(qǐng)求實(shí)例代碼的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06
javascript 刪除dom對(duì)象的事件函數(shù)代碼
本文為《JavaScript高級(jí)程序設(shè)計(jì)》第9章中的跨平臺(tái)事件中的部分內(nèi)容。2010-04-04

