JavaScript中的Moment.js與Day.js時(shí)間處理庫用法詳解

在前端開發(fā)中,處理日期和時(shí)間是常見需求,但原生 JavaScript 的 Date 對象功能有限且 API 不夠友好。Moment.js 和 Day.js 是兩個(gè)流行的時(shí)間處理庫,它們提供了簡潔易用的 API 來簡化日期操作。
1、Moment.js
Moment.js 是一個(gè)歷史悠久的時(shí)間處理庫,提供了全面的日期格式化、解析、計(jì)算和國際化支持。
優(yōu)點(diǎn):
- 支持日期計(jì)算、格式化、時(shí)區(qū)處理等幾乎所有場景。
- 是通過鏈?zhǔn)秸{(diào)用實(shí)現(xiàn)復(fù)雜操作。
- 完善的國際化和本地化支持
- 社區(qū)成熟,文檔完善,生態(tài)豐富。
缺點(diǎn):
- 體積較大:約
67KB,gzip后約20KB+,可能影響應(yīng)用加載速度。 - 可變對象設(shè)計(jì),容易產(chǎn)生引用問題,例如在同一個(gè)方法多次調(diào)用 moment 方法,會(huì)產(chǎn)生數(shù)據(jù)異常。
- 性能相對較差。
- 官方停止維護(hù),進(jìn)入維護(hù)模式。
Tree-shaking支持不佳。
2、常見用法
// 引入 Moment.js
import moment from 'moment';
// 1. 獲取當(dāng)前時(shí)間
const now = moment();
// 2. 格式化日期
console.log(now.format('YYYY-MM-DD HH:mm:ss')); // 2023-05-10 14:30:00
// 3. 日期計(jì)算
const tomorrow = now.add(1, 'days');
const lastWeek = now.subtract(1, 'weeks');
// 4. 相對時(shí)間
console.log(moment('2023-01-01').fromNow()); // 4個(gè)月前
// 5. 解析字符串為日期
const date = moment('2023-05-10', 'YYYY-MM-DD');
// 6. 時(shí)區(qū)處理(需額外加載 moment-timezone)
const laTime = moment.tz('2023-05-10 12:00', 'America/Los_Angeles');
3、Day.js
Day.js 是一個(gè)輕量級的時(shí)間處理庫,設(shè)計(jì)靈感來自 Moment.js,但體積更小,約 2KB ,性能更高。它的 API 與 Moment.js 兼容,適合現(xiàn)代前端項(xiàng)目,新項(xiàng)目推薦使用。
優(yōu)點(diǎn):
- 核心體積僅 2KB,適合對包大小敏感的項(xiàng)目。
- 不可變對象設(shè)計(jì),避免了引用問題,所有操作返回新實(shí)例,避免副作用。
- API 兼容 Moment,幾乎完全繼承 Moment 的 API,遷移成本低。
- 支持
Tree-shaking,按需加載。 - 性能優(yōu)秀,現(xiàn)代化設(shè)計(jì),活躍維護(hù),持續(xù)更新。
- 按需加載插件,避免引入無用代碼。
缺點(diǎn):
- 功能相對 Moment 較少,需要使用插件引用。
- 國際化需要額外支持。
- 社區(qū)相對較新。
4、常見用法
// 引入 Day.js
import dayjs from 'dayjs';
import utc from 'dayjs/plugin/utc'; // 按需加載插件
// 使用插件
dayjs.extend(utc);
// 1. 獲取當(dāng)前時(shí)間
const now = dayjs();
// 2. 格式化日期
console.log(now.format('YYYY-MM-DD HH:mm:ss')); // 2023-05-10 14:30:00
// 3. 日期計(jì)算
const tomorrow = now.add(1, 'day');
const lastWeek = now.subtract(1, 'week');
// 4. 相對時(shí)間(需加載 relativeTime 插件)
console.log(dayjs('2023-01-01').fromNow()); // 4個(gè)月前
// 5. 解析字符串為日期
const date = dayjs('2023-05-10', 'YYYY-MM-DD');
// 6. 時(shí)區(qū)處理(需加載 utc 和 timezone 插件)
const laTime = dayjs.utc('2023-05-10 12:00').tz('America/Los_Angeles');
5、JS 原生 API
如果項(xiàng)目對體積要求極高且僅需簡單功能,可使用原生 API。
優(yōu)點(diǎn):無需額外依賴,瀏覽器原生支持,性能最好,占用內(nèi)存少,所有JS環(huán)境都支持。
缺點(diǎn):
- API 設(shè)計(jì)不夠直觀,月份從 0 開始計(jì)算。
- 時(shí)區(qū)處理復(fù)雜,并且容易出錯(cuò),日期計(jì)算和格式化功能有限。
- 可變對象,容易產(chǎn)生副作用。
6、常見方法
// 1. 格式化日期
const now = new Date();
console.log(`${now.getFullYear()}-${String(now.getMonth() + 1).padStart(2, '0')}-${String(now.getDate()).padStart(2, '0')}`);
// 2. 日期計(jì)算
const tomorrow = new Date(now);
tomorrow.setDate(now.getDate() + 1);
// 3. 相對時(shí)間(簡單實(shí)現(xiàn))
const getRelativeTime = (date) => {
const diff = (new Date() - date) / 1000;
if (diff < 60) return `${Math.floor(diff)}秒前`;
if (diff < 3600) return `${Math.floor(diff / 60)}分鐘前`;
return `${Math.floor(diff / 3600)}小時(shí)前`;
};
7、對比與選擇建議
| 特性 | 原生API | Moment.js | Day.js |
|---|---|---|---|
| 體積 | 原生 | ~20KB+(gzip 后) | ~2KB(gzip 后) |
| 兼容性 | 跨瀏覽器有兼容問題 | 支持 IE8+ | 現(xiàn)代瀏覽器(IE 需 polyfill) |
| API 設(shè)計(jì) | 可變數(shù)據(jù)(可能有副作用) | 可變數(shù)據(jù)(可能有副作用) | 不可變數(shù)據(jù)(更安全) |
| 生態(tài) | 使用比較復(fù)雜 | 插件豐富,社區(qū)成熟 | 插件逐漸完善 |
| 適用場景 | 對日期要求不高的場景 | 復(fù)雜項(xiàng)目、需兼容舊瀏覽器 | 對體積敏感的項(xiàng)目 |
選擇建議:
- 新項(xiàng)目:優(yōu)先使用
Day.js,體積小且性能高。 - 遺留項(xiàng)目:若已使用
Moment.js且功能穩(wěn)定,可繼續(xù)使用;若需優(yōu)化體積,可考慮遷移到Day.js。 - 國際化需求:兩者均支持,但
Day.js的國際化文件需單獨(dú)引入。
總結(jié):
Moment.js適合功能全面、兼容性要求高的項(xiàng)目。Day.js適合追求極致性能和體積的現(xiàn)代項(xiàng)目。- 原生 API 適合簡單場景,避免引入額外依賴。
到此這篇關(guān)于JavaScript中的Moment.js與Day.js時(shí)間處理庫用法的文章就介紹到這了,更多相關(guān)JS Moment.js與Day.js時(shí)間處理庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
TypeScript中l(wèi)et和var的區(qū)別介紹
這篇文章主要介紹了TypeScript?let與var的區(qū)別,主要從作用域等這幾個(gè)方面做詳細(xì)介紹,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07
onsubmit阻止form表單提交與onclick的相關(guān)操作
return false會(huì)阻止表單提交,基本上關(guān)于onsubmit=return false有以下幾點(diǎn)要注意的地方,學(xué)習(xí)后臺(tái)編程的朋友一定要知道。2010-09-09
原生JS控制多個(gè)滾動(dòng)條同步跟隨滾動(dòng)效果
本文要探討的是,當(dāng)這兩個(gè)容器元素的內(nèi)容都超出了容器高度,即都出現(xiàn)了滾動(dòng)框的時(shí)候,如何在其中一個(gè)容器元素滾動(dòng)時(shí),讓另外一個(gè)元素也隨之滾動(dòng)2017-12-12
一個(gè)JavaScript操作元素定位元素的實(shí)例
操作元素定位元素,大家會(huì)想到使用js來實(shí)現(xiàn),下面有個(gè)不錯(cuò)的示例,大家可以看看2014-10-10
實(shí)現(xiàn)圖片首尾平滑輪播(JS原生方法—節(jié)流)
下面小編就為大家?guī)硪黄獙?shí)現(xiàn)圖片首尾平滑輪播(JS原生方法—節(jié)流)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10
JS如何實(shí)現(xiàn)網(wǎng)站中PC端和手機(jī)端自動(dòng)識(shí)別并跳轉(zhuǎn)對應(yīng)的代碼
這篇文章主要介紹了JS如何實(shí)現(xiàn)網(wǎng)站中PC端和手機(jī)端自動(dòng)識(shí)別并跳轉(zhuǎn)對應(yīng)的代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01

