在前端开发中,时间和日期的处理是很常见的一个问题。而对于不同的国家和地区,时间和日期的表示方式也是不同的,这就需要前端开发人员进行格式化。在 ECMAScript 2020 版本中,引入了时间日期格式化语言包 Intl(Internationalization API),这个新特性为前端开发人员提供了更好的解决方案。
Intl 简介
Intl 提供了一系列 API,用于处理国际化相关的内容,包括:
- 日期和时间的格式化
- 数字格式化
- 货币格式化
- 排序和比较字符串
其中,我们这篇文章主要介绍日期和时间格式化相关的 API,这些 API 是通过 Intl.DateTimeFormat() 来实现的。
Intl.DateTimeFormat() 方法
Intl.DateTimeFormat() 方法用于创建一个日期和时间格式化对象。该方法接受两个参数,分别是表示语言和地区的参数和表示日期和时间格式的参数。
下面是一个简单的例子:
const date = new Date('2020/01/01'); const dateTimeFormat = new Intl.DateTimeFormat('zh-CN', { year: 'numeric', month: 'long', day: 'numeric' }); console.log(dateTimeFormat.format(date)); // 输出:2020年1月1日
上面的例子中,我们创建了一个日期和时间格式化对象,该对象的语言和地区是中国大陆('zh-CN'),日期格式是年月日,使用拼音表示月份。
接下来,我们就详细介绍 Intl.DateTimeFormat() 的各个参数和使用方法。
表示语言和地区的参数
Intl.DateTimeFormat() 方法的第一个参数表示语言和地区(Locale),这个参数是一个字符串类型的值,例如:
- 'zh-CN':中国大陆,简体中文
- 'zh-TW':中国台湾,繁体中文
- 'en-US':美国,英语
- 'ja-JP':日本,日语
使用这个参数,可以实现不同地区和语言下的时间和日期格式化。
表示日期和时间格式的参数
Intl.DateTimeFormat() 方法的第二个参数表示日期和时间的格式,这个参数是一个对象类型的值,其中包含各种属性,用来控制日期和时间的格式。
其中,以下是常用的格式属性:
- year:年份的表示方式,例如 'numeric'、'2-digit'
- month:月份的表示方式,例如 'numeric'、'2-digit'、'narrow'、'short'、'long'
- day:日期的表示方式,例如 'numeric'、'2-digit'
- hour:小时的表示方式,例如 'numeric'、'2-digit'
- minute:分钟的表示方式,例如 'numeric'、'2-digit'
- second:秒钟的表示方式,例如 'numeric'、'2-digit'
使用这些属性,就可以实现各种不同的时间和日期格式。
示例代码
下面是一些示例代码,演示了如何利用 Intl.DateTimeFormat() 方法来格式化时间和日期。
1. 格式化日期
const date = new Date('2020/01/01'); const dateTimeFormat = new Intl.DateTimeFormat('zh-CN', { year: 'numeric', month: 'long', day: 'numeric' }); console.log(dateTimeFormat.format(date)); // 输出:2020年1月1日
2. 格式化时间
const date = new Date('2020/01/01 12:00:00'); const dateTimeFormat = new Intl.DateTimeFormat('zh-CN', { hour: 'numeric', minute: 'numeric', second: 'numeric' }); console.log(dateTimeFormat.format(date)); // 输出:12:00:00
3. 格式化日期和时间
const date = new Date('2020/01/01 12:00:00'); const dateTimeFormat = new Intl.DateTimeFormat('zh-CN', { year: 'numeric', month: 'long', day: 'numeric', hour: 'numeric', minute: 'numeric', second: 'numeric' }); console.log(dateTimeFormat.format(date)); // 输出:2020年1月1日 12:00:00
4. 格式化为指定时区的日期和时间
const date = new Date('2020/01/01 12:00:00'); const dateTimeFormat = new Intl.DateTimeFormat('zh-CN', { year: 'numeric', month: 'long', day: 'numeric', hour: 'numeric', minute: 'numeric', second: 'numeric', timeZone: 'America/New_York' }); console.log(dateTimeFormat.format(date)); // 输出:2020年1月1日 11:00:00
总结
在 ECMAScript 2020 版本中引入的 Intl 是一个非常有用的国际化方案,尤其是对于日期和时间的处理,提供了非常便利的方式。在实际开发中,我们可以根据不同的需求和地区来选择不同的格式选项,使得我们的应用更加适合不同的用户。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/654a1ddc7d4982a6eb44a787