JavaScript獲取某一天所在的星期
導語: 如何獲取今天或者某一天所在星期的開始和結束日期,或者如何獲取整個星期的日期
我們會遇到的需求的是,獲取今天或者某一天所在星期的開始和結束日期。
我們這里來獲取今天所在星期的始末日期,我們可以通過 (new Date).getDay() 來獲取今天是星期幾,然后再通過這個減去或者加上一定的天數(shù),就是這個星期的開始日期和結束日期。
function getWeekStartAndEnd() { const oneDayTime = 1000 * 60 * 60 * 24; // 一天里一共的毫秒數(shù) const today = new Date(); const todayDay = today.getDay(); // 獲取今天是星期幾,假設是周3 const startDate = new Date( today.getTime() - oneDayTime * (todayDay - 1) ); const endDate = new Date(today.getTime() + oneDayTime * (7 - todayDay)); return { startDate, endDate }; } const week = getWeekStartAndEnd(); console.log(week.startDate, week.endDate);
是不是很完美?但,這里有一個很大的 bug! 注意:如果今天是周日,那么 todayDay 就會是 0,若還是按照上面的思路,則星期一的日期會變成下周一的日期,星期日的日期會變成下周日的日期 。因此,這里我們需要特殊處理下,當 todayDay 為 0 時,就將其賦值為 7。同時,我們還可以傳入一個時間戳,獲取特定某一天所在的星期。
最終的解決方案
function getWeekStartAndEnd(timestamp) { const oneDayTime = 1000 * 60 * 60 * 24; // 一天里一共的毫秒數(shù) const today = timestamp ? new Date(timestamp) : new Date(); const todayDay = today.getDay() || 7; // 若那一天是周末時,則強制賦值為7 const startDate = new Date( today.getTime() - oneDayTime * (todayDay - 1) ); const endDate = new Date(today.getTime() + oneDayTime * (7 - todayDay)); return { startDate, endDate }; }
擴展
如果我要輸出今天所在星期,這一周里所有的日期,該怎么辦呢?很簡單,先獲取到這一周里的第一天,然后第一天加上 oneDayTime*i
的時間戳,就是第 i 天的日期,或者在前一天的基礎上加上 oneDayTime 也可以。
function getAllWeekToday() { const oneDayTime = 1000 * 60 * 60 * 24; const today = new Date(); const todayDay = today.getDay() || 7; // 若那一天是周末時,則強制賦值為7 const startDate = new Date( today.getTime() - oneDayTime * (todayDay - 1) ); let dateList = [startDate]; for (let i = 1; i < 7; i++) { dateList.push(new Date(startDate.getTime() + oneDayTime * i)); } return dateList; }
總結
以上所述是小編給大家介紹的JavaScript獲取某一天所在的星期,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!
相關文章
javascript showModalDialog模態(tài)對話框使用說明
使用javascript打開模態(tài)對話框,想學習showModalDialog使用方法的朋友可以參考下。2009-12-12js或者jquery判斷圖片是否加載完成實現(xiàn)代碼
需要獲得圖片的寬度和高度,有些js或者jquery代碼在還沒有加載完圖片時就執(zhí)行了,這個問題該怎么解決呢?接下來分別介紹下js與jquery提供的方法2013-03-03Javascript實現(xiàn)hashcode函數(shù)實現(xiàn)對象比較與原理說明
在JavaScript中,數(shù)值的比較是比較簡單的,使用相等(==)和全等(===)符號基本上可以解決大多數(shù)非對象的比較。但是相等(==)和全等(===)符號在對象 object 的比較上,就不能滿足所有的要求了2023-06-06用Javascript輕松制作一套簡單的抽獎系統(tǒng)
用Javascript輕松制作一套簡單的抽獎系統(tǒng)...2006-12-12javascript實現(xiàn)10個球隨機運動、碰撞實例詳解
這篇文章主要介紹了javascript實現(xiàn)10個球隨機運動、碰撞的方法,實例分析了javascript實現(xiàn)小球碰撞的原理與實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-07-07