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)文章
js中異步函數(shù)async function變同步函數(shù)的簡(jiǎn)單入門
這篇文章主要介紹了js中異步函數(shù)async function變同步函數(shù)的簡(jiǎn)單入門,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04JS獲取一個(gè)表單字段中多條數(shù)據(jù)并轉(zhuǎn)化為json格式
這篇文章主要介紹了JS獲取一個(gè)表單字段中多條數(shù)據(jù)并轉(zhuǎn)化為json格式的相關(guān)資料,需要的朋友可以參考下2017-10-10JavaScript String 對(duì)象常用方法總結(jié)
下面小編就為大家?guī)硪黄狫avaScript String 對(duì)象常用方法總結(jié)。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考2016-04-04JavaScript函數(shù)的4種調(diào)用方法詳解
了解函數(shù)的調(diào)用過程有助于深入學(xué)習(xí)與分析JavaScript代碼。本文是JavaScript高級(jí)這個(gè)系列中的第三篇文章,主要介紹JavaScript中函數(shù)的四種使用形式2014-04-04使用js判斷TextBox控件值改變?nèi)缓蟪霭l(fā)事件
這篇文章主要介紹了使用js判斷TextBox控件值改變?nèi)缓蟪霭l(fā)事件。需要的朋友可以過來參考下,希望對(duì)大家有所幫助2014-03-03JS實(shí)現(xiàn)5秒鐘自動(dòng)封鎖div層的方法
這篇文章主要介紹了JS實(shí)現(xiàn)5秒鐘自動(dòng)封鎖div層的方法,涉及javascript針對(duì)div層操作的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02關(guān)于layui flow loading占位圖的實(shí)現(xiàn)方法
今天小編就為大家分享一篇關(guān)于layui flow loading占位圖的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-09-09