插件是一些独立的程序,可以给 Day.js 增加新功能和扩展已有功能
默认情况下,Day.js 只包含核心的代码,并没有安装任何插件
您可以加载多个插件来满足您的需求
- 将返回dayjs类
使用插件
import plugin
dayjs.extend(plugin)
dayjs.extend(plugin, options) // 带�参数加载插件
- 通过 NPM:
import dayjs from 'dayjs'
import advancedFormat from 'dayjs/plugin/advancedFormat' // 按需加载
dayjs.extend(advancedFormat) // 使用插件
- 通过 CDN:
<script src="https://unpkg.com/dayjs"></script>
<!-- 通过 window.dayjs_plugin_NAME 获取 -->
<script src="https://unpkg.com/dayjs/plugin/advancedFormat"></script>
<script>
dayjs.extend(dayjs_plugin_advancedFormat);
</script>
- AdvancedFormat 扩展了
dayjs().format
API 以支持更多模版
import AdvancedFormat from 'dayjs/plugin/advancedFormat'
dayjs.extend(AdvancedFormat)
dayjs().format('Q Do k kk X x')
扩展的模版列表:
模版 | 输出 | 简介 |
---|---|---|
Q |
1-4 | 季度 |
Do |
1st 2nd ... 31st | 带序号的月份 |
k |
1-23 | 时:由 1 开始 |
kk |
01-23 | 时:由 1 开始,二位数 |
X |
1360013296 | 秒为单位的Unix时间戳 |
x |
1360013296123 | 毫秒单位的Unix时间戳 |
- RelativeTime 增加了
.from
.to
.fromNow
.toNow
4个 API 来展示相对的时间 (e.g. 3 小时以前).
import relativeTime from 'dayjs/plugin/relativeTime'
dayjs.extend(relativeTime)
dayjs().from(dayjs('1990')) // 2 年以前
dayjs().from(dayjs(), true) // 2 年
dayjs().fromNow()
dayjs().to(dayjs())
dayjs().toNow()
返回 string
距离现在的相对时间
返回 string
距离 X 的相对时间
返回 string
到现在的相对时间
返回 string
到 X 的相对时间
Range | Key | Sample Output |
---|---|---|
0 到 44 秒 | s | 几秒前 |
45 到 89 秒 | m | 1 分钟前 |
90 秒 到 44 分 | mm | 2 分钟前 ... 44 分钟前 |
45 到 89 分 | h | 1 小时前 |
90 分 到 21 小时 | hh | 2 小时前 ... 21 小时前 |
22 到 35 小时 | d | 1 天前 |
36 小时 到 25 天 | dd | 2 天前 ... 25 天前 |
26 到 45 天 | M | 1 个月前 |
46 天 到 10 月 | MM | 2 个月前 ... 10 个月前 |
11 月 到 17月 | y | 1 年前 |
18 月以上 | yy | 2 年前 ... 20 年前 |
- IsLeapYear 增加了
.isLeapYear
API 返回一个boolean
来展示一个Dayjs
's 的年份是不是闰年.
import isLeapYear from 'dayjs/plugin/isLeapYear'
dayjs.extend(isLeapYear)
dayjs('2000-01-01').isLeapYear(); // true
- BuddhistEra 扩展了
dayjs().format
API 以支持佛历格式化. - 佛教时代是一个年份编号系统,主要用于柬埔寨、老挝、缅甸和泰国等东南亚国家以及斯里兰卡、马来西亚和新加坡的中国人,用于宗教或官方场合([Wikipedia](https://en.wikipedia.org/wiki/Buddhist_calendar))
- 要计算BE年,只需在年份中添加543。 例如,1977年5月26日AD / CE应显示为2520年5月26日BE(1977 + 543)
import buddhistEra from 'dayjs/plugin/buddhistEra'
dayjs.extend(buddhistEra)
dayjs().format('BBBB BB')
List of added formats:
Format | Output | Description |
---|---|---|
BBBB |
2561 | Full BE Year (Year + 543) |
BB |
61 | 2-digit of BE Year |
- WeekOfYear 增加了
.week()
API 返回一个number
来表示Dayjs
的日期是年中第几周.
import weekOfYear from 'dayjs/plugin/weekOfYear'
dayjs.extend(weekOfYear)
dayjs('06/27/2018').week() // 26
- IsBetween 增加了
.isBetween()
API 返回一个boolean
来展示一个时间是否介于两个时间之间.
import isBetween from 'dayjs/plugin/isBetween'
dayjs.extend(isBetween)
dayjs('2010-10-20').isBetween('2010-10-19', dayjs('2010-10-25')); // true
你可以根据需要自由的编写一个Day.js插件
欢迎提交PR与大家分享你的插件
Day.js插件模版
export default (option, dayjsClass, dayjsFactory) => {
// 扩展 dayjs() 实例
// 例:添加 dayjs().isSameOrBefore() 实例方法
dayjsClass.prototype.isSameOrBefore = function (arguments) {}
// 扩展 dayjs 类
// 例:添加 dayjs.utc() 类方法
dayjsFactory.utc = (arguments) => {}
// 覆盖已存在的 API
// 例:�扩展 dayjs().format() 方法
const oldFormat = dayjsClass.prototype.format
dayjsClass.prototype.format = function (arguments) {
// 原始format结果
const result = oldFormat(arguments)
// 返回修改后结果
}
}