⏰ Moment.js 宣布停止开发,现在该用什么?

2020-09-17 10:06:20 +08:00
 iamkun

本文整理自 Monent.js 官方英文公告 https://momentjs.com/docs/#/-project-status/

Moment.js 宣布停止开发,进入维护状态。

这是一个大而全的时间日期库,极大方便了我们在 JavaScript 中计算时间和日期,每周下载量超过 1200 万,已成功用于数百万个项目中。

但是,作为一个诞生于 2011 年的元老级明星项目,以现在的眼光来看 Moment.js 并非完美无缺,官方总结了两大问题:

1. 可变对象

Moment 对象是可变对象( mutable ),简单点说,任何时间上的加减等计算都改变了其本身。这种设计让代码变的十分不可控,而且很容易带来各种隐蔽且难以调试的 bug 。以至于我们在每步修改之前,都要先调用 .clone 克隆一次才能放心操作。

2. 包体积过大

因为 Momnet.js 将全部的功能和所有支持的语言都打到一个包里,包的大小也是到了 280.9 kB 这样一个夸张的数字,而且对于 Tree shaking 无效。如果要使用时区相关的功能,包体积更是有 467.6 kB 的大小。简单点说,我们可能只需要一个 .format 格式化时间的方法,用户就需要加载数百 kB 的库,这是十分不划算的。

最新版本的 Chrome 开发者工具也开始建议用户更换 Moment.js 为同类更小的库。

现在,Moment.js 停止开发了,那我们接下来该用什么呢?

官方给了 3 种替代方案:

1. 不使用库

对于一些简单的时间处理需求,其实 JavaScript 自带的 DateIntl 对象完全可以满足。强大的 Intl 对象可以展示不同时区不同语言的时间日期格式,在多数现代浏览器上已经有很好的支持。

2. Temporal

也许今后的某一天,我们再也不需要使用任何库,被看作是未来的全新内置的时间日期方案 Temporal 很值得期待。这是一个 JS 语言内置的重新设计的时间和日期 API,现在可以通过实验性的 polyfill 来尝试 Temporal,但离生产上大规模可用还有很长的路要走。

3. 其他替代库

官方推荐了 Luxon,Day.js ,date-fns 等更先进设计更优秀的时间日期库。相比之下可能 Day.js 是最值得尝试的一个。

Day.js

官方推荐语:Day.js 被设计为 Moment.js 的极简替代品,拥有几乎一样的 API 。如果你习惯使用 Moment 的 API 并希望快速入门,请考虑使用 Day.js 。

上面说到了官方总结的 Moment.js 的两点设计缺陷,可变对象降低了代码的维护性,过大的包体积影响了影响了整个项目的加载速度。

而将近 3 万 Github StarDay.js 的设计理念与这份总结不谋而合。在保持了优秀的 API 设计不变的同时,引入不可变对象( immutable )减少了开发时所需的心智成本,同时简化逻辑使整个包体积仅有 2 kB 大小。

https://github.com/iamkun/dayjs

Day.js 是一个轻量的 JavaScript 时间日期处理库,和 Moment.js 的 API 设计保持完全一样. 如果你曾经用过 Moment.js, 那么你已经知道如何使用 Day.js

Day.js 基本用法如下,相同的 API,相同的链式操作,熟悉的味道。

dayjs()
    .startOf('month')
    .add(1, 'day')
    .set('year', 2018)
    .format('YYYY-MM-DD HH:mm:ss');

感谢 Moment.js 前辈的付出,让我们的开发体验变的更好,期待接过接力棒的 Day.js 能让时间日期处理再也不是难题 💖,也期待未来 JavaScript 内置的时间日期新方案能让我们使用 Vanilla js 解决一切问题。

3117 次点击
所在节点    分享发现
6 条回复
liushuangbill
2020-09-17 10:14:59 +08:00
喜欢 date-fns
liyang5945
2020-09-17 10:16:05 +08:00
dayjs
zazzaz
2020-09-17 10:18:57 +08:00
说的很中肯,简单日期处理用 Date 就足够了, 搞不定的我选 Day.js
justin2018
2020-09-17 10:39:14 +08:00
dayjs
luxon
day-fns
revalue
2020-09-17 10:46:56 +08:00
我更好奇 dayjs 是怎么做到替代 momentjs 的功能的,就是跟进了一下包管理机制?
AlynxZhou
2020-09-17 12:21:32 +08:00
我自己的项目直接重新设计了一下需求,用 Date 和 Intl.DateTimeFormat 搞定了,早就想把这个大家伙去掉了,只是没下定决心砍需求……

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/707798

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX