[英]JavaScript ISO Date to human readable
我在 JS 中得到一个像2014-07-04
这样的日期,而不是时间。 我想将该 ISO 日期转换为人类可读的格式。 例如: July 4, 2014
使用 Intl 来格式化日期。 查看 MDN 链接以获取有关 Intl 的更多信息
const date = new Date('2014-07-04'); const dateTimeFormat = new Intl.DateTimeFormat('en', { year: 'numeric', month: 'long', day: 'numeric', }); console.log(dateTimeFormat.format(date));
function humanizeDate(date_str) { month = ['January', 'Feburary', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December']; date_arr = date_str.split('-'); return month[Number(date_arr[1]) - 1] + " " + Number(date_arr[2]) + ", " + date_arr[0] } date_str = '2014-07-04'; console.log(humanizeDate(date_str));
您问题中的日期2014-07-04
不是ISO 格式。 ISO 格式日期的一个示例是2014-07-04T18:06:08-07:00
。 如果我们想将其转换为July 4, 2014
,一种方法是使用 JavaScript 的 Date 构造函数。
var isoformat = 2014-07-04T18:06:08-07:00;
var readable = new Date(isoformat);
变量readable
现在保存字符串Fri Jul 04 2014 21:06:08 GMT-0400 (Eastern Daylight Time)
。 从这里开始,我们需要将月、日和年放在自己的变量中。
var m = readable.getMonth(); // returns 6
var d = readable.getDay(); // returns 15
var y = readable.getFullYear(); // returns 2012
由于月份由数字表示,因此我们定义了一个月份数组,以便我们可以找到月份的名称。
var months = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"]
为了获得名称,我们使用m
的值来定位我们想要的数组中的索引。
var mlong = months[m];
如果您还没有注意到, m
比对应于 7 月的数字小 1( m = 6
但 7 月是一年中的第 7 个月)。 不过,这不是问题,因为数组中的第一个索引为零,这意味着我们的months
数组中的索引 6 等于July
。
我们的最后一步是将它们放在一起。
var fulldate = mlong + " " + d + ", " + y;
见小提琴。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.