Dayjs 時間庫

簡介

Dayjs 是一個輕量級的 JavaScript 時間庫, 號稱是 “Moment.js 的替代品”。Dayjs 跟 Moment.js 非常相似,但是有更小的體積(2KB less)和更快的速度。它是一個簡單易用,功能強大的時間處理工具庫。Dayjs 支持時間格式化、時間戳轉換、時間計算,以及基本的標準時間操作等。

安裝

你可以通過 NPM 安裝 Dayjs:

npm install dayjs --save

如果你想在瀏覽器中使用 Dayjs,可以通過 CDN 引入:

<script src="https://cdn.jsdelivr.net/npm/dayjs"></script>

用法

1、時間格式化

Dayjs 允許格式化時間以顯示所需的值。可以使用以下格式化字符:

  • YYYY: 四位數完整年份, 例如 2022
  • YY: 兩位數縮寫年份, 例如 22
  • MMMM: 完整中文月份, 例如 1月
  • MMM: 縮寫中文月份, 例如 1月
  • MM: 兩位數帶前導零的月份, 例如 01
  • M: 無前導零的月份, 例如 1
  • DD: 兩位數帶前導零的日期, 例如 01
  • D: 無前導零的日期, 例如 1
  • HH: 兩位數帶前導零的小時, 例如 01
  • H: 無前導零的小時, 例如 1
  • mm: 兩位數帶前導零的分鐘, 例如 01
  • m: 無前導零的分鐘, 例如 1
  • ss: 兩位數帶前導零的秒數, 例如 01
  • s: 無前導零的秒數, 例如 1

Dayjs 提供了一種方法來替換這些格式字符的值。以下是一些常見的示例:

“`javascript
import dayjs from ‘dayjs’;

const now = dayjs();
const timeString = now.format(“YYYY年MM月DD日 HH:mm:ss”);
console.log(timeString);

// 輸出: 2022年01月01日 01:01:01
“`

2、時間戳轉換

Dayjs 也可以將時間戳轉換為日期對象。只需將時間戳傳遞給 Dayjs,然後使用格式化字符獲取格式化值。以下是一個示例:

“`javascript
import dayjs from ‘dayjs’;

const timestamp = 1640999564247;
const date = dayjs(timestamp);
const dateString = date.format(‘YYYY-MM-DD HH:mm:ss’);
console.log(dateString);

// 輸出: 2022-01-01 01:01:04
“`

3、時間計算

Dayjs 也提供了一些簡單易用的時間計算功能,比如減去或添加天數、小時、分鐘等。以下是一些示例:

“`javascript
import dayjs from ‘dayjs’;

// 得到天數差
const date1 = dayjs(‘2022-01-01’);
const date2 = dayjs(‘2022-01-05’);
const diff = date2.diff(date1, ‘day’);
console.log(diff);

// 輸出: 4

// 得到當天凌晨時間戳
const today = dayjs().startOf(‘day’).valueOf();
console.log(today);

// 自定義時間格式
const date3 = dayjs(‘2022-01-01 12:00:00’);
const date4 = date3.add(1, ‘hour’).subtract(30, ‘minute’);
const formattedDate = date4.format(‘YYYY-MM-DD HH:mm:ss’);
console.log(formattedDate);

// 輸出: 2022-01-01 12:30:00
“`

總結

Dayjs 是一個非常實用的 JavaScript 時間處理庫。它支持時間格式化、時間戳轉換、時間計算等基本的時間操作,而且具有輕量、快速等特點。Dayjs 確實是 “Moment.js 的替代品”,對於前端時間處理有很大的幫助。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/312530.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2025-01-06 09:47
下一篇 2025-01-06 09:47

相關推薦

  • 解決docker-compose 容器時間和服務器時間不同步問題

    docker-compose是一種工具,能夠讓您使用YAML文件來定義和運行多個容器。然而,有時候容器的時間與服務器時間不同步,導致一些不必要的錯誤和麻煩。以下是解決方法的詳細介紹…

    編程 2025-04-29
  • 想把你和時間藏起來

    如果你覺得時間過得太快,每天都過得太匆忙,那麼你是否曾經想過想把時間藏起來,慢慢享受每一個瞬間?在這篇文章中,我們將會從多個方面,詳細地闡述如何想把你和時間藏起來。 一、一些時間管…

    編程 2025-04-28
  • 計算斐波那契數列的時間複雜度解析

    斐波那契數列是一個數列,其中每個數都是前兩個數的和,第一個數和第二個數都是1。斐波那契數列的前幾項為:1,1,2,3,5,8,13,21,34,…。計算斐波那契數列常用…

    編程 2025-04-28
  • 時間戳秒級可以用int嗎

    時間戳是指從某個固定的時間點開始計算的已經過去的時間。在計算機領域,時間戳通常使用秒級或毫秒級來表示。在實際使用中,我們經常會遇到需要將時間戳轉換為整數類型的情況。那麼,時間戳秒級…

    編程 2025-04-28
  • 如何在ACM競賽中優化開發時間

    ACM競賽旨在提高程序員的算法能力和解決問題的實力,然而在比賽中優化開發時間同樣至關重要。 一、規劃賽前準備 1、提前熟悉比賽規則和題目類型,了解常見算法、數據結構和快速編寫代碼的…

    編程 2025-04-28
  • 使用JavaScript日期函數掌握時間

    在本文中,我們將深入探討JavaScript日期函數,並且從多個視角介紹其應用方法和重要性。 一、日期的基本表示與獲取 在JavaScript中,使用Date對象來表示日期和時間,…

    編程 2025-04-28
  • Java Date時間大小比較

    本文將從多個角度詳細闡述Java中Date時間大小的比較,包含了時間字符串轉換、日期相減、使用Calendar比較、使用compareTo方法比較等多個方面。相信這篇文章能夠對你解…

    編程 2025-04-27
  • 二分查找時間複雜度為什麼是logN – 知乎

    二分查找是一種常用的查找算法。它通過將目標值與數組的中間元素進行比較,從而將查找範圍縮小一半,直到找到目標值。這種方法的時間複雜度為O(logN)。下面我們將從多個方面探討為什麼二…

    編程 2025-04-27
  • One change 時間:簡化項目開發的最佳實踐

    本文將介紹 One change 時間 (OCT) 的定義和實現方法,並探討它如何簡化項目開發。OCT 是一種項目開發和管理的策略,通過將更改限制在固定的時間間隔(通常為一周)內,…

    編程 2025-04-27
  • Java Date 比較時間大小

    本文將從以下方面對 Java Date 比較時間大小進行詳細闡述: 一、比較方法的介紹 Java Date 類提供了多種比較時間大小的方法,其中比較常用的包括: compareTo…

    編程 2025-04-27

發表回復

登錄後才能評論