date-fns:日期工具庫

是一個(gè)處理時(shí)間的工具庫,之前我們用的最多的是moment盗扒。date-fns工具庫體積小跪楞,但是常規(guī)處理基本都囊括了。

下載安裝
npm install --save date-fns
引入:按需引入
import {xxx} from date-fns
import { zhCN } from "date-fns/locale"; // 設(shè)置locale

下面是現(xiàn)目前項(xiàng)目中用到的幾個(gè)方法:

1.formatRFC3339():轉(zhuǎn)RFC3339格式
參數(shù):
formatRFC3339(date: number | Date, options?: {
    fractionDigits?: 0 | 3 | 1 | 2 | undefined;
} | undefined): string  //  第二個(gè)參數(shù)是精度
eg: 
console.log(formatRFC3339(new Date())); // 2021-08-10T11:21:53+08:00
console.log(formatRFC3339(new Date(), { fractionDigits: 3 })); // 2021-08-10T11:27:30.543+08:00
2.format():格式化日期
參數(shù):
format(date: number | Date, format: string, options?: {
    locale?: Locale | undefined;  // locale為中國時(shí)間
    weekStartsOn?: 0 | 1 | 2 | 3 | 4 | 5 | 6 | undefined;
    firstWeekContainsDate?: number | undefined;
    useAdditionalWeekYearTokens?: boolean | undefined;
    useAdditionalDayOfYearTokens?: boolean | undefined;
} | undefined): string
eg:
    console.log(format(new Date(), "yyyy-MM-dd HH:mm:ss", { locale: zhCN })); //  2021-08-10 11:42:31
    console.log(format(new Date(), "yyyy-MM-dd HH:mm:ss")); // 2021-08-10 11:38:44
    console.log(format(new Date(), "yyyy-MM-dd")); // 2021-08-10
    console.log(format(new Date(), "HH:mm:ss")); // 11:38:44
3.addDays():計(jì)算某天加減多少天數(shù)是哪一天
參數(shù):
addDays(date: number | Date, amount: number): Date
eg:
    console.log(addDays(new Date(), 1));  // Wed Aug 11 2021 11:47:07 GMT+0800 (中國標(biāo)準(zhǔn)時(shí)間)
    console.log(addDays(new Date(), -1));  // Mon Aug 09 2021 11:47:07 GMT+0800 (中國標(biāo)準(zhǔn)時(shí)間)
    console.log(addDays(new Date(), -29)); // Mon Jul 12 2021 11:47:07 GMT+0800 (中國標(biāo)準(zhǔn)時(shí)間)

同樣用法的還有:
addMonths():幾個(gè)月后的日期侣灶,
addHours():幾個(gè)小時(shí)后的日期甸祭,
addMinutes():幾分鐘后的日期
addWeeks():幾個(gè)周后的日期

4.getDate(): 獲取傳入日期的天
參數(shù):
getDate(date: number | Date): number
eg:
    console.log(new Date()); // Tue Aug 10 2021 13:56:16 GMT+0800 (中國標(biāo)準(zhǔn)時(shí)間)
    console.log(getDate(new Date())); // 10
    console.log(getDate(addDays(new Date(), -2))); // 8

同樣用法的還有:
getYear():獲取傳入時(shí)間的年份,
getMonth():獲取傳入時(shí)間的月份褥影,
getDay():獲取傳入時(shí)間是星期幾

5.isAfter():判斷日期1是否在日期2之后
參數(shù):
isAfter(date: number | Date, dateToCompare: number | Date): boolean
eg:
    console.log(isAfter(new Date(), new Date("2020-12-11"))); // true
    console.log(isAfter(addDays(new Date(), -2), new Date())); // false

同樣用法的還有:
isBefore():判斷日期1是否在日期2之前

6.isSameDay():判斷兩個(gè)日期是否是同一天(同年同月同日)
參數(shù):
isSameDay(dateLeft: number | Date, dateRight: number | Date): boolea
eg:
console.log(isSameDay(new Date(), new Date("2021-8-10"))); // true

同樣用法的還有:
isSameMonth():判斷兩個(gè)日期是否在同一月(同年同月)
isSameHour():判斷兩個(gè)時(shí)間是否是同一個(gè)小時(shí)(同一天的小時(shí)判斷)

7.startOfMonth():獲取傳入日期所在月份的第一天的時(shí)間
參數(shù):
startOfMonth(date: number | Date): Date
eg:
console.log(startOfMonth(new Date("2020-12-11"))); // Tue Dec 01 2020 00:00:00 GMT+0800 (中國標(biāo)準(zhǔn)時(shí)間)

同樣用法的還有:
startOfYear():獲取傳入日期所在年份的第一天的時(shí)間
startOfDay():獲取傳入日期的零點(diǎn)日期
startOfWeek():獲取傳入日期所在星期的第一天的零點(diǎn)時(shí)間

startOfWeek(date: Date | number, options?: {
    locale?: globalThis.Locale | undefined;
    weekStartsOn?: 0 | 1 | 2 | 3 | 4 | 5 | 6 | undefined;
} | undefined): Date  // 因?yàn)橹袊瞧诘钠鹗紩r(shí)間和國際的星期開始時(shí)間有差異池户,所以需要設(shè)置了可選項(xiàng)
8.isToday():判斷傳入日期是否是當(dāng)天
參數(shù):
isToday(date: Date | number): boolean
eg:
console.log(isToday(new Date()); // true

同樣用法的還有:
isYesterday():判斷傳入日期是否是昨天
isTomorrow():判斷傳入日期是否是明天

9.subDays(): 獲取傳入日期n天以前的日期
參數(shù):
subDays(date: number | Date, amount: number): Date
eg:
console.log(subDays(new Date("2020-12-11"), 20)); // Sat Nov 21 2020 08:00:00 GMT+0800 (中國標(biāo)準(zhǔn)時(shí)間)

同樣用法的還有:
subMonths():獲取傳入日期之前n個(gè)月的時(shí)間
subHours(): 獲取傳入時(shí)間之前n小時(shí)的時(shí)間
subMinutes(): 獲取傳入時(shí)間之前n分鐘的時(shí)間

10.differenceInDays():計(jì)算兩個(gè)時(shí)間之間相差的天數(shù)
參數(shù):
differenceInDays(dateLeft: number | Date, dateRight: number | Date): number
eg:
console.log(differenceInDays(new Date("2021-10-20"), new Date("2021-10-1"))); // 19

同樣用法的還有:
differenceInMonths():計(jì)算兩個(gè)時(shí)間之間相差的月份
differenceInYears():計(jì)算兩個(gè)時(shí)間之間相差的年數(shù)
differenceInHours():計(jì)算兩個(gè)時(shí)間之間相差的小時(shí)
differenceInWeeks():計(jì)算兩個(gè)時(shí)間之間相差的周數(shù)

11.parseISO():將字符串形式的日期轉(zhuǎn)換成Date格式的日期
參數(shù):
parseISO(argument: string, options?: {
    additionalDigits?: 0 | 1 | 2 | undefined;
} | undefined): Date
eg:
console.log(parseISO("2021-12-19")); // Sun Dec 19 2021 00:00:00 GMT+0800 (中國標(biāo)準(zhǔn)時(shí)間)

當(dāng)然如果是RFC3339格式的字符串日期也可以轉(zhuǎn)。


持續(xù)更新中凡怎。校焦。。统倒。寨典。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市房匆,隨后出現(xiàn)的幾起案子耸成,更是在濱河造成了極大的恐慌,老刑警劉巖浴鸿,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件井氢,死亡現(xiàn)場離奇詭異,居然都是意外死亡岳链,警方通過查閱死者的電腦和手機(jī)花竞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來掸哑,“玉大人左胞,你說我怎么就攤上這事【倩В” “怎么了烤宙?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長俭嘁。 經(jīng)常有香客問我躺枕,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任拐云,我火速辦了婚禮罢猪,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘叉瘩。我一直安慰自己膳帕,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布薇缅。 她就那樣靜靜地躺著危彩,像睡著了一般。 火紅的嫁衣襯著肌膚如雪泳桦。 梳的紋絲不亂的頭發(fā)上汤徽,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天,我揣著相機(jī)與錄音灸撰,去河邊找鬼谒府。 笑死,一個(gè)胖子當(dāng)著我的面吹牛浮毯,可吹牛的內(nèi)容都是我干的完疫。 我是一名探鬼主播,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼债蓝,長吁一口氣:“原來是場噩夢啊……” “哼壳鹤!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起惦蚊,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎讯嫂,沒想到半個(gè)月后蹦锋,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡欧芽,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年莉掂,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片千扔。...
    茶點(diǎn)故事閱讀 39,834評論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡憎妙,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出曲楚,到底是詐尸還是另有隱情厘唾,我是刑警寧澤,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布龙誊,位于F島的核電站抚垃,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜鹤树,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一铣焊、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧罕伯,春花似錦曲伊、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至湿酸,卻和暖如春婿屹,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背推溃。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工昂利, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人铁坎。 一個(gè)月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓蜂奸,卻偏偏與公主長得像,于是被迫代替她去往敵國和親硬萍。 傳聞我的和親對象是個(gè)殘疾皇子扩所,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評論 2 354

推薦閱讀更多精彩內(nèi)容