摘要:下面,我將自己閱讀的源碼的過程記錄下來。閱讀庫的代碼,首先先要知道這個庫的作用是一個輕量的時間日期處理庫,其用法和完全一樣。介紹首先,閱讀的源碼,我們應該從的入手。對象是不可變的,即所有改變的操作都會返回一個新的實例。
前言
作為一個程序員,閱讀別人優秀代碼是提升自己技術能力的一個很好的方法。下面,我將自己閱讀 dayjs(v1.6.10)的源碼的過程記錄下來。
閱讀庫的代碼,首先先要知道這個庫的作用dayjs 是一個輕量的 JavaScript 時間日期處理庫,其用法(api)和 Moment.js 完全一樣。
特點和 Moment.js 相同的 api 和用法
不可變數據(Immutable)
支持鏈式操作(Chainable)
l18n國際化
僅 2kb 大小
全瀏覽器兼容
因為其 api 和 Moment.js 完全相同,所以你可以將之前使用 Moment.js 的項目無痛的遷移使用 dayjs。
API 介紹(v1.6.10)首先,閱讀 dayjs 的源碼,我們應該從 dayjs 的 api 入手。
官方 api 文檔(中文) 官方 api 文檔(英文)
Day.js 沒有修改原生的 Date.prototype,而是在 Date 對象基礎上包裝了一層,叫做 Dayjs 對象。Dayjs 對象是不可變的,即所有改變 Dayjs 的操作都會返回一個新的實例。
其中,api 分為 6 類:
解析
構造 dayjs(existing?:string | number | Date | Dayjs):構造一個 Dayjs 實例對象
克隆 .clone() | dayjs(original: Dayjs):在已有 Dayjs 實例對象的基礎上克隆返回一個新的 Dayjs 實例對象
驗證 .isValid():驗證該 Dayjs 實例對象是否有效
獲取和設置
年 .year()
月 .month()
日 .date()
星期幾 .day()
時 .hour()
分 .minute()
秒 .second()
毫秒 .millisecond()
設置 .set(unit: string, value: number)
操作
添加 .add(value: number, unit: string)
減少 .subtract(value: number, unit: string)
開始的時間 .startOf(unit: string)
結束的時間 .endOf(unit: string)
展示
格式化 .format(stringWithTokens: string)
差別 .diff(compared: Dayjs, unit: string (default: "milliseconds"), float?: boolean)
Unix 時間戳(毫秒) .valueOf()
Unix 時間戳(秒) .unix()
某月的天數 .daysInMonth()
轉換為 JavaScript Date 對象 .toDate
轉換為數組 .toArray()
轉換為 JSON .toJSON()
轉換為 ISO 8601 標準格式的字符串 .toISOString()
轉換為對象 .toObject()
轉換為字符串 .toString()
查詢
是否在之前 .isBefore(compared: Dayjs)
是否相同 .isSame(compared: Dayjs)
是否在之后 .isAfter(compared: Dayjs)
是否是 Dayjs 實例對象 isDayjs()
插件
相對時間
是否是閏年
API 詳解(v1.6.10) 解析 構造器 dayjs(existing?: string | number | Date | Dayjs)1.當沒有參數時,會返回一個新的 Dayjs 實例對象,且為當前日期和時間
dayjs()
2.當參數為 ISO 8601 標準的字符串時
dayjs("2018-07-01T12:00:00.000Z")
3.當參數為 unix 時間戳時
dayjs(1318781876406);
4.當參數為一個原生的 JavaScript Date 對象時
dayjs(new Date(2018, 7, 1));
dayjs() 構造函數會返回一個 Dayjs 實例對象
克隆 .clone() | dayjs(original: Dayjs)會克隆返回一個新的 Dayjs 對象,有兩種方法
// 1.使用 .clone() 方法 dayjs().clone() // 2.使用 dayjs 構造函數,且傳入的參數為被克隆的 Dayjs 實例對象 dayjs(dayjs("2018-7-1"))驗證 .isValid()
返回一個布爾值,表示該 Dayjs 實例對象是否有效
dayjs().isValid()獲取和設置 獲取(年,月,日,星期幾,時,分,秒,毫秒)
// 年 dayjs().year() // 月 dayjs().month() // 日 dayjs().date() // 星期幾 dayjs().day() // 時 dayjs().hour() // 分 dayjs().minute() // 秒 dayjs().second() // 毫秒 dayjs().millisecond()
上面返回的值與用原生 Date.prototype 對象下的方法獲取 “年月日...” 的值是一樣的,其實在源碼中,就是使用的 Date 的原生方法獲取的 “年月日...”
設置 .set(unit: string, value: number)返回一個新的日期時間被改變的 Dayjs 實例對象
dayjs().set("date", 1) // 設置 “日” 為 1 日 dayjs().set("month", 3) // 設置 “月” 為 4 月 dayjs().set("second", 30) // 設置 “秒” 為 30 秒操作
Dayjs 實例對象可以使用很多方法操作
dayjs("2018-7-1") .add(1, "day") .substract(1, "year").toString() // 在 2018-7-1 基礎上添加 1 天,然后減少 1 年,最后轉換為字符串添加 .add(value: number, unit: string)
dayjs().add(7. "day")減少 .subtract(value: number, unit: string)
dayjs().subtract(7. "year")開始的時間
返回克隆的以傳入的單位開始時間的 Dayjs 實例對象
dayjs().startOf("week") // 本周開始的時間結束的時間
返回克隆的以傳入的單位結束時間的 Dayjs 實例對象
dayjs().endOf("month") // 本月的結束時間展示 格式化 .format(stringWidthTokens: string)
返回一個按照你規定好的格式化后的字符串
dayjs().format(); // current date in ISO6801, without fraction seconds e.g. "2020-04-02T08:02:17-05:00" dayjs("2019-01-25").format("{YYYY} MM-DDTHH:mm:ssZ[Z]"); // "{2019} 01-25T00:00:00-02:00Z" dayjs("2019-01-25").format("DD/MM/YYYY"); // "25/01/2019"
可用的格式
差別 .diff(compared: Dayjs, unit: string (default: "milliseconds"), float?: boolean)返回兩個 Dayjs 實例對象的時間差
const date1 = dayjs("2019-01-25"); const date2 = dayjs("2018-06-05"); date1.diff(date2); // 20214000000 date1.diff(date2, "months"); // 7 date1.diff(date2, "months", true); // 7.645161290322581 date1.diff(date2, "days"); // 233unix 時間戳(毫秒) .valueOf()
dayjs("2019-01-25").valueOf(); // 1548381600000unix 時間戳(秒) .unix()
dayjs("2019-01-25").unix(); // 1548381600某月的天數 .daysInMonth()
dayjs("2018-7-1").daysInMonth() // 31轉換為(原生 Date 對象 | 數組 | json | ISO 8601 字符串 | 對象 | 字符串)
// 1.轉換為 原生 Date 對象 dayjs("2019-01-25").toDate() // 2.轉換為 數組 dayjs("2019-01-25").toArray() // [ 2019, 0, 25, 0, 0, 0, 0 ] // 3.轉換為 json dayjs("2019-01-25").toJSON() // "2019-01-25T02:00:00.000Z" // 4.轉換為 ISO 8601 字符串 dayjs("2019-01-25").toISOString() // "2019-01-25T02:00:00.000Z" // 5.轉換為 ISO 8601 字符串 dayjs("2019-01-25").toObject() /* { years: 2019, months: 0, date: 25, hours: 0, minutes: 0, seconds: 0, milliseconds: 0 } */ // 6.轉換為 字符串 dayjs("2019-01-25").toString() // "Fri, 25 Jan 2019 02:00:00 GMT"查詢 是否在之前 .isBefore(compared: Dayjs)
dayjs().isBefore(dayjs()); // false是否相同
dayjs().isSame(dayjs()); // true是否在之后
dayjs().isAfter(dayjs()); // false是否是 Dayjs 實例對象
dayjs.isDayjs(dayjs()); // true dayjs.isDayjs(new Date()); // false是否是閏年(在 1.7.0 版本被棄用,請使用 IsLeapYear plugin 插件替代)
dayjs("2000-01-01").isLeapYear(); // true插件 相對時間
使用 .from .to .fromNow .toNow 方法來獲得相對時間
是否是閏年使用 .from .to .fromNow .toNow 方法來獲得相對時間
下一篇,dayjs 源碼解析(二)(目錄結構)
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/95838.html
摘要:前言上一篇源碼解析四類介紹了的源碼目錄結構。接下來,本篇將分析一下中插件功能的用法源碼以及如何編寫自己的插件。并且,可以通過插件選項,來對插件進行配置。 前言 上一篇 dayjs 源碼解析(四)(Dayjs 類)介紹了 dayjs 的源碼目錄結構。接下來,本篇將分析一下 dayjs 中插件功能的用法、源碼以及如何編寫自己的 dayjs 插件。 dayjs 插件用法 dayjs 的插件,...
摘要:前言上一篇源碼解析一,介紹了一下的,知道了如何使用。本篇,介紹項目的目錄結構。源碼解析三構造函數 前言 上一篇 dayjs 源碼解析(一)(api),介紹了一下 dayjs 的 api,知道了如何使用 dayjs。本篇,介紹 dayjs 項目的目錄結構。 目錄結構 showImg(https://segmentfault.com/img/bVbcW0Q?w=229&h=832); 在 ...
摘要:接下來,本篇將解讀一下中的構造函數。最后將傳入類的構造函數,生成一個對象,作為函數的返回值給返回了。參數通過上面對參數的分析知道了參數其實是當參數為實例對象時,最后又會調用函數,此時才會傳入參數。 前言 上一篇 dayjs 源碼解析(二)(目錄結構)介紹了 dayjs 的源碼目錄結構。接下來,本篇將解讀一下 index.js 中的 dayjs 構造函數。 dayjs 構造函數 // ...
摘要:前言上一篇源碼解析三構造函數介紹了的源碼中的函數。接下來,本篇將解讀一下中的類。首先,我們看的構造函數,該構造函數調用了實例方法,傳入參數在上一篇有講到。下一篇源碼解析五插件詳解 前言 上一篇 dayjs 源碼解析(三)(dayjs 構造函數)介紹了 dayjs 的源碼中的 dayjs 函數。接下來,本篇將解讀一下 index.js 中的 Dayjs 類。 class Dayjs { ...
showImg(https://segmentfault.com/img/bV9wV7?w=1952&h=712);Moment.js 是一個大而全的 JS 時間庫,很大地方便了我們處理日期和時間。但是 Moment.js太重了(200k+ with locals),可能一般項目也只使用到了她幾個常用的API。雖然社區也有幾個輕量的時間庫,要想遷移過去又會增加新的學習和遷移成本。 如果能有一個和 ...
閱讀 3520·2023-04-25 17:35
閱讀 2595·2021-11-24 09:39
閱讀 2534·2021-10-18 13:32
閱讀 3421·2021-10-11 10:58
閱讀 1639·2021-09-26 09:55
閱讀 6161·2021-09-22 15:47
閱讀 969·2021-08-26 14:15
閱讀 3474·2019-08-30 15:55