@TOCjava
實際開發過程當中,咱們有許許多多的產品都設計到了時間,也有時候須要本身轉化時間格式,這裏推薦一個日期時間處理類庫momentjs,但不少時候,咱們僅僅是轉化個別時間,還不必安裝這麼一個依賴;這篇文章將在將來持續更新,蒐羅各類關於時間轉化的方法git
// 中國標準時間format yyyy-mm-dd
const format = (time) => {
let ymd = ''
let mouth = (time.getMonth() + 1) >= 10 ? (time.getMonth() + 1) : ('0' + (time.getMonth() + 1))
let day = time.getDate() >= 10 ? time.getDate() : ('0' + time.getDate())
ymd += time.getFullYear() + '-' // 獲取年份。
ymd += mouth + '-' // 獲取月份。
ymd += day // 獲取日。
return ymd // 返回日期。
}
export const getAllDate = (start, end) => {
let dateArr = []
let startArr = start.split('-')
let endArr = end.split('-')
let db = new Date()
db.setUTCFullYear(startArr[0], startArr[1] - 1, startArr[2])
let de = new Date()
de.setUTCFullYear(endArr[0], endArr[1] - 1, endArr[2])
let unixDb = db.getTime()
let unixDe = de.getTime()
let stamp
const oneDay = 24 * 60 * 60 * 1000;
for (stamp = unixDb; stamp <= unixDe;) {
dateArr.push(format(new Date(parseInt(stamp))))
stamp = stamp + oneDay
}
return dateArr
}
...
// 使用
console.log(getAllDate('2018-12-12', '2019-3-3'))
複製代碼
結果以下: github
最近七天:bash
// 中國標準時間format yyyy-mm-dd
const format = (time) => {
let ymd = ''
let mouth = (time.getMonth() + 1) >= 10 ? (time.getMonth() + 1) : ('0' + (time.getMonth() + 1))
let day = time.getDate() >= 10 ? time.getDate() : ('0' + time.getDate())
ymd += time.getFullYear() + '-' // 獲取年份。
ymd += mouth + '-' // 獲取月份。
ymd += day // 獲取日。
return ymd // 返回日期。
}
export const getWeekDate = () => {
let myDate = new Date()
// 獲取前一週時間
const oneDay = 24 * 60 * 60 * 1000;
let oneweekdate = new Date(myDate - 7 * oneDay)
let lastWeek = []
lastWeek.push(format(oneweekdate))
lastWeek.push(format(myDate))
return lastWeek
}
...
// 使用
console.log(getWeekDate())
複製代碼
控制檯輸出結果: ui
最近一個月:spa
// 中國標準時間format yyyy-mm-dd
const format = (time) => {
let ymd = ''
let mouth = (time.getMonth() + 1) >= 10 ? (time.getMonth() + 1) : ('0' + (time.getMonth() + 1))
let day = time.getDate() >= 10 ? time.getDate() : ('0' + time.getDate())
ymd += time.getFullYear() + '-' // 獲取年份。
ymd += mouth + '-' // 獲取月份。
ymd += day // 獲取日。
return ymd // 返回日期。
}
export const getMonthDate = () => {
let nowDate = new Date()
let nowDateChange = new Date()
let lastMonth = []
// 獲取前一月時間
nowDateChange.setMonth(nowDateChange.getMonth() - 1)
lastMonth.push(format(nowDateChange))
lastMonth.push(format(nowDate))
return lastMonth
}
...
// 使用
console.log(getMonthDate())
複製代碼
輸出以下: 設計
最近三個月// 中國標準時間format yyyy-mm-dd
const format = (time) => {
let ymd = ''
let mouth = (time.getMonth() + 1) >= 10 ? (time.getMonth() + 1) : ('0' + (time.getMonth() + 1))
let day = time.getDate() >= 10 ? time.getDate() : ('0' + time.getDate())
ymd += time.getFullYear() + '-' // 獲取年份。
ymd += mouth + '-' // 獲取月份。
ymd += day // 獲取日。
return ymd // 返回日期。
}
export const getThreeMonthDate = () => {
let nowDate = new Date()
let nowDateChange = new Date()
let threeMonth = []
// 獲取前三月時間
nowDateChange.setMonth(nowDateChange.getMonth() - 3)
threeMonth.push(format(nowDateChange))
threeMonth.push(format(nowDate))
return threeMonth
}
...
// 使用
console.log(getThreeMonthDate())
複製代碼
輸出以下: 3d
一年unix
const format = (time) => {
let ymd = ''
let mouth = (time.getMonth() + 1) >= 10 ? (time.getMonth() + 1) : ('0' + (time.getMonth() + 1))
let day = time.getDate() >= 10 ? time.getDate() : ('0' + time.getDate())
ymd += time.getFullYear() + '-' // 獲取年份。
ymd += mouth + '-' // 獲取月份。
ymd += day // 獲取日。
return ymd // 返回日期。
}
export const getYearDate = () => {
let nowDate = new Date()
let nowDateChange = new Date()
let lastYear = []
// 獲取前一年時間
nowDateChange.setFullYear(nowDateChange.getFullYear()- 1)
lastYear.push(format(nowDateChange))
lastYear.push(format(nowDate))
return lastYear
}
...
// 使用
console.log(getYearDate())
複製代碼
輸出以下: code
關於JavaScript Date 對象的方法詳情請轉@W3 school
更多文章請看個人博客@王一諾 感謝閱讀!