Day.js 是一个轻量的处理时间和日期的 JavaScript 库,和 Moment.js 的 API 设计保持完全一样. 如果您曾经用过 Moment.js, 那么您已经知道如何使用 Day.js
npm install dayjs --save
import dayjs from 'dayjs'
// 或者 CommonJS
// var dayjs = require('dayjs');
dayjs().format()
Dayjs
并没有改变或覆盖 Javascript 原生的 Date.prototype
, 而是创造了一个全新的包含 Javascript Date
对象的 Dayjs
的对象。
Dayjs
对象是不可变的, 所有的 API 操作都将返回一个新的 Dayjs
对象。
如果没有特别说明,Day.js 的返回值都是新的 Dayjs
对象。
在 dayjs()
中传入支持的格式
直接运行 dayjs()
,得到包含当前时间和日期的 Dayjs
对象。
dayjs()
可以解析传入的一个标准的ISO 8601时间字符串。
dayjs(String)
dayjs('1995-12-25')
可以解析传入的一个 Javascript Date 对象。
dayjs(Date)
dayjs(new Date(2018, 8, 18))
可以解析传入的一个 Unix 时间戳 (13 位数字)。
dayjs(Number)
dayjs(1318781876406)
可以解析传入的一个 Unix 时间戳 (10 位数字)。
dayjs.unix(Number)
dayjs.unix(1318781876)
dayjs("12-25-1995", "MM-DD-YYYY")
可以使用插件 CustomParseFormat
Dayjs
对象是不可变的,如果您想获得一个对象的拷贝,请执行 .clone()
。
向 dayjs()
里传入一个 Dayjs
对象也能实现同样的效果。
dayjs(Dayjs)
dayjs().clone()
检测当前 Dayjs
对象是否是一个有效的时间。
dayjs().isValid()
获取和改变日期。
获取或设置年份。
dayjs().year()
dayjs().year(2000)
获取或设置月份。从 0 开始
dayjs().month()
dayjs().month(0)
获取或设置日期。从 1 开始
dayjs().date()
dayjs().date(1)
获取或设置星期。从星期天 0 开始
dayjs().day()
dayjs().day(0)
获取或设置小时。
dayjs().hour()
dayjs().hour(12)
获取或设置分钟。
dayjs().minute()
dayjs().minute(59)
获取或设置秒。
dayjs().second()
dayjs().second(1)
获取或设置毫秒。
dayjs().millisecond()
dayjs().millisecond(1)
获取从 Dayjs
对象中取到的信息
传入的单位 (unit) 对大小写不敏感。
dayjs().get(unit : String)
dayjs().get('month') // 从 0 开始
dayjs().get('day')
单位 | 缩写 | 描述 |
---|---|---|
date |
日期 | |
day |
d |
星期几 (星期天 0, 星期六 6) |
month |
M |
月 (一月 0, 十二月 11) |
year |
y |
年 |
hour |
h |
时 |
minute |
m |
分 |
second |
s |
秒 |
millisecond |
ms |
毫秒 |
设置时间
dayjs().set(unit : String, value : Int);
dayjs().set('date', 1);
dayjs().set('month', 3); // 四月
dayjs().set('second', 30);
您可以对 Dayjs
对象如下增加减少之类的操作:
dayjs()
.startOf('month')
.add(1, 'day')
.subtract(1, 'year')
增加时间并返回一个新的 Dayjs()
对象。
dayjs().add(value : Number, unit : String);
dayjs().add(7, 'day');
减少时间并返回一个新的 Dayjs()
对象。
dayjs().subtract(value : Number, unit : String);
dayjs().subtract(7, 'year');
返回当前时间的开头时间的 Dayjs()
对象,如月份的第一天。
dayjs().startOf(unit : String);
dayjs().startOf('week'); // 取决于 locale 文件里 `weekStart` 的值
返回当前时间的末尾时间的 Dayjs()
对象,如月份的最后一天。
dayjs().endOf(unit : String);
dayjs().endOf('month');
格式化 Dayjs
对象并展示。
接收一系列的时间日期字符串并替换成相应的值。
dayjs().format(String)
dayjs('2019-01-25').format('[YYYY] YYYY-MM-DDTHH:mm:ssZ[Z]') // 'YYYY 2019-01-25T00:00:00-02:00Z'
dayjs().format('{YYYY} MM-DDTHH:mm:ssZ[Z]') // "{2014} 09-08T08:02:17-05:00Z"
详情如下:
格式 | 输出 | 描述 |
---|---|---|
YY |
18 | 两位数的年份 |
YYYY |
2018 | 四位数的年份 |
M |
1-12 | 月份,从 1 开始 |
MM |
01-12 | 月份,两位数 |
MMM |
Jan-Dec | 简写的月份名称 |
MMMM |
January-December | 完整的月份名称 |
D |
1-31 | 月份里的一天 |
DD |
01-31 | 月份里的一天,两位数 |
d |
0-6 | 一周中的一天,星期天是 0 |
dd |
Su-Sa | 最简写的一周中一天的名称 |
ddd |
Sun-Sat | 简写的一周中一天的名称 |
dddd |
Sunday-Saturday | 一周中一天的名称 |
H |
0-23 | 小时 |
HH |
00-23 | 小时,两位数 |
h |
1-12 | 小时, 12 小时制 |
hh |
01-12 | Hours, 12 小时制, 两位数 |
m |
0-59 | 分钟 |
mm |
00-59 | 分钟,两位数 |
s |
0-59 | 秒 |
ss |
00-59 | 秒 两位数 |
SSS |
000-999 | 毫秒 三位数 |
Z |
+5:00 | UTC 的偏移量 |
ZZ |
+0500 | UTC 的偏移量,数字前面加上 0 |
A |
AM PM | |
a |
am pm |
Q Do k kk X x ...
可以使用插件 AdvancedFormat
L LT LTS ...
可以使用插件 LocalizedFormat
获取两个 Dayjs
对象的时间差,默认毫秒。
const date1 = dayjs('2019-01-25')
const date2 = dayjs('2018-06-05')
date1.diff(date2) // 20214000000
date1.diff(date2, 'month') // 7
date1.diff(date2, 'month', true) // 7.645161290322581
date1.diff(date2, 'day') // 233
返回 Unix 时间戳 (毫秒)
dayjs().valueOf()
返回 Unix 时间戳 (秒)。
dayjs().unix()
返回 UTC 偏移量 (分)
dayjs().utcOffset()
返回月份的天数。
dayjs().daysInMonth()
Date
object返回原生的 Date
对象。
dayjs().toDate()
当序列化 Dayjs
对象时,会返回 ISO8601 格式的字符串。
dayjs().toJSON() //"2018-08-08T00:00:00.000Z"
返回 ISO8601 格式的字符串。
dayjs().toISOString()
dayjs().toString()
检查一个 Dayjs
对象是否在另一个 Dayjs
对象时间之前。
dayjs().isBefore(Dayjs, unit? : String);
dayjs().isBefore(dayjs()); // false
dayjs().isBefore(dayjs(), 'year'); // false
检查一个 Dayjs
对象是否和另一个 Dayjs
对象时间相同。
dayjs().isSame(Dayjs, unit? : String);
dayjs().isSame(dayjs()); // true
dayjs().isSame(dayjs(), 'year'); // true
检查一个 Dayjs
对象是否在另一个 Dayjs
对象时间之后。
dayjs().isAfter(Dayjs, unit? : String);
dayjs().isAfter(dayjs()); // false
dayjs().isAfter(dayjs(), 'year'); // false
.isDayjs(compared: any)
返回一个 boolean
验证传入值是否是一个 Dayjs 对象.
dayjs.isDayjs(dayjs()) // true
dayjs.isDayjs(new Date()) // false
也可以使用 instanceof
dayjs() instanceof dayjs // true
如果想要使用 UTC 模式来解析和展示时间,.utc
.local
.isUTC
可以使用插件 UTC
.from
.to
.fromNow
.toNow
获得相对时间
插件 RelativeTime
.isLeapYear
获得是否闰年
插件 IsLeapYear
.week
获取是第几个周
插件 WeekOfYear
.weekday
来获取或设置当前语言的星期
plugin WeekDay
.isoWeeksInYear
获得年中有几周
plugin IsoWeeksInYear
.isSameOrAfter
返回一个时间和一个时间相同或在一个时间之后
插件 IsSameOrAfter
.isSameOrBefore
返回一个时间是否和一个时间相同或在一个时间之前
插件 IsSameOrBefore
.isBetween
返回一个时间是否介于两个时间之间
插件 IsBetween
.quarter
返回年中第几季度
插件 QuarterOfYear
.toArray
返回包含时间数值的数组。
插件 ToArray
.toObject
返回包含时间数值的对象
插件 ToObject
.min
.max
比较传入的 dayjs 实例的大小
plugin MinMax
.calendar
来显示日历时间
plugin Calendar
更多最新内容参考:https://github.com/iamkun/dayjs/blob/master/docs/zh-cn/README.zh-CN.md