欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2025年07月24日 11:19:53   作者:青燈文案  
Moment.js是一個(gè)在JavaScript開發(fā)中廣泛使用的日期處理庫,它的出現(xiàn)極大地方便了開發(fā)者在處理日期和時(shí)間上的需求,這篇文章主要介紹了JavaScript中的Moment.js與Day.js時(shí)間處理庫用法的相關(guān)資料,需要的朋友可以參考下

在前端開發(fā)中,處理日期和時(shí)間是常見需求,但原生 JavaScript 的 Date 對象功能有限且 API 不夠友好。Moment.jsDay.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、對比與選擇建議

特性原生APIMoment.jsDay.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)文章

  • js模擬實(shí)現(xiàn)煙花特效

    js模擬實(shí)現(xiàn)煙花特效

    這篇文章主要為大家詳細(xì)介紹了js模擬實(shí)現(xiàn)煙花特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • TypeScript中l(wèi)et和var的區(qū)別介紹

    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)操作

    onsubmit阻止form表單提交與onclick的相關(guān)操作

    return false會(huì)阻止表單提交,基本上關(guān)于onsubmit=return false有以下幾點(diǎn)要注意的地方,學(xué)習(xí)后臺(tái)編程的朋友一定要知道。
    2010-09-09
  • js中toString()與valueOf()的使用

    js中toString()與valueOf()的使用

    tostring 和 valueOf 函數(shù)是解決值的顯示和運(yùn)算的問題,本文主要介紹了js中toString()與valueOf()的使用,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • 原生JS控制多個(gè)滾動(dòng)條同步跟隨滾動(dòng)效果

    原生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
  • 如何寫JS數(shù)組sort的比較函數(shù)

    如何寫JS數(shù)組sort的比較函數(shù)

    我們知道,數(shù)組的sort方法可以對數(shù)組元素進(jìn)行排序,默認(rèn)是按ASCII字母表順序排序。如果要根據(jù)其他的順序排序就需要為sort方法提供一個(gè)比較函數(shù)作為參數(shù)。這里講的就是如何寫這個(gè)比較函數(shù)。
    2010-07-07
  • 一個(gè)JavaScript操作元素定位元素的實(shí)例

    一個(gè)JavaScript操作元素定位元素的實(shí)例

    操作元素定位元素,大家會(huì)想到使用js來實(shí)現(xiàn),下面有個(gè)不錯(cuò)的示例,大家可以看看
    2014-10-10
  • 實(shí)現(xiàn)圖片首尾平滑輪播(JS原生方法—節(jié)流)

    實(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)識別并跳轉(zhuǎn)對應(yīng)的代碼

    JS如何實(shí)現(xiàn)網(wǎng)站中PC端和手機(jī)端自動(dòng)識別并跳轉(zhuǎn)對應(yīng)的代碼

    這篇文章主要介紹了JS如何實(shí)現(xiàn)網(wǎng)站中PC端和手機(jī)端自動(dòng)識別并跳轉(zhuǎn)對應(yīng)的代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • JS實(shí)現(xiàn)手寫 forEach算法示例

    JS實(shí)現(xiàn)手寫 forEach算法示例

    這篇文章主要介紹了JS實(shí)現(xiàn)手寫 forEach算法,結(jié)合實(shí)例形式分析了JS實(shí)現(xiàn)手寫 forEach算法實(shí)現(xiàn)原理與相關(guān)操作技巧,需要的朋友可以參考下
    2020-04-04

最新評論