Day.js中文網Day.js是一個極簡的JavaScript庫,可以為現代瀏覽器解析、驗證、操作和顯示日期和時間。https://dayjs.fenxianglu.cn/
單位不區別大小寫,支持復數和縮寫形式
單位 | 縮寫 | 描述 |
---|---|---|
date | D | 日期 [1,31] |
day | d | 星期 [0,6](星期日0,星期六6) |
month | M | 月份 [0,11] (0表示1月份) |
year | y | 年 [1,31] |
hour | h | 小時 [0,23] |
minute | m | 分鐘 [0,59] |
second | s | 秒 [0,59] |
millisecond | ms | 毫秒 [0,999] |
?把dayjs()對象當成一個中轉站,往后所有的關于日期的計算都先轉成dayjs()對象,再進行加減等運行。?
一、下載dayjs
cnpm i -S dayjs
二、引入dayjs
如果在node中,引入方式為:let dayjs=require('dayjs')
如果在vue項目中,在main.js中全局引入:
import dayjs from "dayjs"
Vue.prototype.$dayjs = dayjs;
局部引入只需:import dayjs from "dayjs"即可?
dayjs()對象:
即當前時間,dayjs()等價于dayjs(Date.now())、dayjs(new Date())
dayjs()對象格式化:?
格式化dayjs()對象為YYYY-MM-DD HH:mm:ss格式:?
?
?
?從dayjs()對象中獲取年月日時分秒:
?代碼:
console.log("dayjs().get('year'):", dayjs().get("year")); //年 [1,366]console.log("dayjs().get('month'):", dayjs().get("month")); //月 [0,11] 0表示1月console.log("dayjs().get('date'):", dayjs().get("date")); //日[1,31]console.log("dayjs().get('hour'):", dayjs().get("hour")); //時 [0,23]console.log("dayjs().get('minute'):", dayjs().get("minute")); //分 [0,59]console.log("dayjs().get('second'):", dayjs().get("second")); //秒 [0,59]console.log("dayjs().get('millisecond'):", dayjs().get("millisecond")); //毫秒[0,999]console.log("dayjs().get('day'):", dayjs().get("day")); //星期幾 [0,6]。0(星期日)到6(星期六)
?用單數復數,大寫小寫,縮寫都可以,如year,years,y,Y
dayjs對象-加減指定的時間
console.log("當前時間:", `${this.$dayjs().format("YYYY-MM-DD hh:mm:ss")}`);console.log("昨天:",`${this.$dayjs().subtract(1, "day").format("YYYY-MM-DD")} 00:00:00`);
dayjs對象-判斷2個日期大小?
dayjs對象-判斷某個日期是否在2個日期之間?
?此功能需要引入isBetween
插件,引入方式如下(Day.js 的 isBetween 方法是 Day.js 庫的一部分,因此當你下載和安裝 Day.js 時,isBetween會自動包含在其中):
import isBetween from "dayjs/plugin/isBetween";
dayjs.extend(isBetween);
?測試:
console.log("當前時間:", dayjs().format("YYYY-MM-DD"));console.log('2022-1-1 < 當前時間 < 2022-12-31 嗎?', dayjs().isBetween("2022-1-1", dayjs("2022-12-31")));
?dayjs對象-2個日期之間相差多少時、分、秒等
let time1 = dayjs("2011-7-19 00:00:00");let time2 = dayjs("2011-7-19 01:40:00");console.log("time1:", time1);console.log("time2:", time2);console.log("time1和time2相差多少hour:", time2.diff(time1, "hour"));console.log("time1和time2相差多少minute:", time2.diff(time1, "minute"));console.log("time1和time2相差多少second:", time2.diff(time1, "second"));
各種日期轉dayjs對象
普通時間轉dayjs
中國標準時間轉dayjs?
示例1:?
示例2:
?
示例3:
?
時間戳(ms)轉dayjs
時間戳(s)轉dayjs?
通過new Date().getTime()獲取的時間戳是毫秒級的,為了在某些情況下方便和其他秒級的時間戳比較大小,現需要將毫秒級的轉為秒級的,方式如下:
console.log("new Date():", new Date())console.log("new Date().getTime():", new Date().getTime())console.log("new Date().getTime()/1000:", new Date().getTime() / 1000)console.log("parseInt(new Date().getTime() / 1000):", parseInt(new Date().getTime() / 1000))console.log("Date.parse(new Date())/1000:", Date.parse(new Date()) / 1000)
秒級的時間戳轉dayjs必須用dayjs.unix(),如下:
?