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/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

发表回复

登录后才能评论