JS 将时间戳转换为日期字符串 (5种方法 )

还是大剑师兰特:曾是美国某知名大学计算机专业研究生,现为航空航海领域高级前端工程师;CSDN知名博主,GIS领域优质创作者,深耕openlayers、leaflet、mapbox、cesium,canvas,webgl,echarts等技术开发,欢迎加底部微信(gis-dajianshi),一起交流。

在这里插入图片描述

No.内容链接
1Openlayers 【入门教程】 - 【源代码+示例300+】
2Leaflet 【入门教程】 - 【源代码+图文示例 150+】
3Cesium 【入门教程】 - 【源代码+图文示例200+】
4MapboxGL【入门教程】 - 【源代码+图文示例150+】
5前端就业宝典 【面试题+详细答案 1000+】


当然,以下是JavaScript中将时间戳转换为日期的五种不同方法,包括基础方法及一些进阶技巧:

方法1:使用 Date 构造函数

最直接的方式是通过Date构造函数,将时间戳转为日期对象,然后可以调用各种方法获取年月日等信息,或者直接使用toLocaleString()得到本地化的日期字符串。

function timestampToDateBasic(timestamp) {
  return new Date(timestamp).toLocaleString();
}
console.log(timestampToDateBasic(1609459200000)); // 示例时间戳

方法2:格式化日期字符串

自定义格式输出日期。

function timestampToFormattedDate(timestamp) {
  const date = new Date(timestamp);
  return `${date.getFullYear()}-${('0' + (date.getMonth() + 1)).slice(-2)}-${('0' + date.getDate()).slice(-2)} ${('0' + date.getHours()).slice(-2)}:${('0' + date.getMinutes()).slice(-2)}:${('0' + date.getSeconds()).slice(-2)}`;
}
console.log(timestampToFormattedDate(1609459200000));

方法3:使用国际化的API(Intl.DateTimeFormat)

利用国际化API进行本地化格式化。

function timestampToIntlFormat(timestamp) {
  const formatter = new Intl.DateTimeFormat('default', {
    year: 'numeric',
    month: 'long',
    day: 'numeric',
    hour: 'numeric',
    minute: 'numeric',
    second: 'numeric'
  });
  return formatter.format(new Date(timestamp));
}
console.log(timestampToIntlFormat(1609459200000));

方法4:简易日期格式化库(如moment.jsdate-fns

虽然不是原生JS方法,但这些库提供了强大且灵活的日期处理能力。

使用moment.js(已不再推荐用于新项目,推荐使用date-fns等替代品):

// 需要先引入moment.js库
const moment = require('moment');
function timestampToMoment(timestamp) {
  return moment(timestamp).format('YYYY-MM-DD HH:mm:ss');
}
console.log(timestampToMoment(1609459200000));

使用date-fns

// 需要先引入date-fns库
import { format } from 'date-fns';
function timestampToDateFns(timestamp) {
  return format(new Date(timestamp), 'yyyy-MM-dd HH:mm:ss');
}
console.log(timestampToDateFns(1609459200000));

方法5:ES6模板字符串与解构

结合解构赋值和模板字符串,使代码更加简洁。

function timestampToTemplate(timestamp) {
  const date = new Date(timestamp);
  const {getFullYear, getMonth, getDate, getHours, getMinutes, getSeconds} = date;
  return `${getFullYear()}-${getMonth()+1}-${getDate()} ${getHours()}:${getMinutes()}:${getSeconds()}`;
}
console.log(timestampToTemplate(1609459200000));

以上是五种不同的将时间戳转换为日期字符串的方法,每种方法都有其适用场景,可以根据具体需求选择使用。

### 回答1: JavaScript中的日期可以使用时间戳日期字符串来表示。时间戳是一个数字,表示自1970年1月1日以来的毫秒数。日期字符串则是一段字符串,包含具体的日期和时间信息。在JavaScript中,我们可以通过以下方式将时间戳转换日期字符串: ```javascript const timestamp = 1632797697000; // 时间戳 const dateStr = new Date(timestamp).toLocaleString(); // 将时间戳转换日期字符串 console.log(dateStr); // '2021/9/28 上午10:01:37' ``` 在上面的代码中,我们使用Date对象的toLocaleString()方法时间戳转换为本地日期字符串。如果需要转换为其他格式日期字符串,可以使用其它Date对象的方法。 同样,我们也可以将日期字符串转换时间戳: ```javascript const dateStr = '2021/9/28 上午10:01:37'; // 日期字符串 const timestamp = new Date(dateStr).getTime(); // 将日期字符串转换时间戳 console.log(timestamp); // 1632797697000 ``` 在上面的代码中,我们使用Date对象的getTime()方法日期字符串转换时间戳。需要注意的是,如果日期字符串格式不正确,则无法正确地转换时间戳。因此,在实际使用中,需要根据具体的日期格式来进行转换。 ### 回答2: JavaScript 时间戳日期字符串的相互转换是 Web 开发中经常用到的操作,本文将详细介绍这两类型之间的转换方法。 一、JavaScript 时间戳 JavaScript 时间戳是指从 1970 年 1 月 1 日 00:00:00 UTC(世界标准时间)到某个时间点的毫秒数。JavaScript 中可以使用 Date 对象获取当前时间的时间戳,示例代码如下: ```javascript var timestamp = new Date().getTime(); // 获取当前时间的时间戳 ``` 二、JavaScript 日期字符串 JavaScript 日期字符串是指使用一定的格式表示日期字符串,常见的格式包括: - "YYYY-MM-DD":表示年月日,如 "2021-07-01"; - "YYYY-MM-DD HH:mm:ss":表示年月日时分秒,如 "2021-07-01 11:35:12"。 JavaScript 中可以使用 Date 对象将时间戳转换日期字符串,示例代码如下: ```javascript var timestamp = 1627082112060; // 假设时间戳为 2021-07-24 16:08:32 var date = new Date(timestamp); var dateString = date.toLocaleString(); // 转换为本地日期时间字符串 console.log(dateString); // 输出 "2021/7/24 下午4:08:32" ``` 在上面的代码中,我们首先创建了一个 Date 对象,并传入了一个时间戳作为参数。然后通过 toLocaleString 方法将其转换为了本地日期时间字符串。需要注意的是,toLocaleString 方法的输出结果会受到当前操作系统、浏览器等环境的影响,可能会存在差异。 如果想要自定义日期字符串格式,可以使用 Date 对象的 getFullYear、getMonth、getDate 等方法获取年、月、日等信息,然后使用字符串拼接的方式生成日期字符串。示例如下: ```javascript var timestamp = 1627082112060; // 假设时间戳为 2021-07-24 16:08:32 var date = new Date(timestamp); var year = date.getFullYear(); var month = date.getMonth() + 1; var day = date.getDate(); var hour = date.getHours(); var minute = date.getMinutes(); var second = date.getSeconds(); var dateString = year + '-' + addZero(month) + '-' + addZero(day) + ' ' + addZero(hour) + ':' + addZero(minute) + ':' + addZero(second); console.log(dateString); // 输出 "2021-07-24 16:08:32" function addZero(num) { return num < 10 ? '0' + num : num; } ``` 在上面的代码中,我们使用了一个 addZero 函数将月、日、时、分、秒字符串转换为两位数的格式,使得最终生成的日期字符串符合了常见的格式要求。 三、总结 JavaScript 时间戳日期字符串是常见的日期和时间表示方式,在 Web 开发中经常用到。JavaScript 的 Date 对象提供了丰富的 API,可以方便地进行时间戳日期字符串之间的转换。需要注意的是,toLocaleString 方法输出的本地日期时间字符串可能会受到环境的影响,生成自定义格式日期字符串需要手动拼接各个日期时间部分。 ### 回答3: JavaScript中的时间戳日期字符串是常用的表示时间的方式。时间戳是指从1970年1月1日0时0分0秒(UTC)到指定时间之间的毫秒数。日期字符串则是一个格式化后的字符串,如'2022-01-01 12:00:00'表示2022年1月1日中午12点整。在JavaScript中,我们可以通过一些函数来实现时间戳日期字符串的相互转换。 1. 将日期字符串转换时间戳 我们可以使用JavaScript内置的Date对象中的getTime()方法日期字符串转换时间戳。getTime()方法返回从1970年1月1日0时0分0秒(UTC)到该日期对象所表示时间的毫秒数。 代码示例: ``` let dateStr = '2022-01-01 12:00:00'; let timestamp = new Date(dateStr).getTime(); console.log(timestamp); // 1641038400000 ``` 在这个例子中,我们首先定义了一个日期字符串dateStr,然后用new Date()方法将其转换成Date对象,并使用getTime()方法获取该日期对象的时间戳。最后我们打印了获取到的时间戳。 2. 将时间戳转换日期字符串 同样使用Date对象,我们可以通过构造函数中传入时间戳,然后使用toLocaleString()方法将其转换日期字符串。 代码示例: ``` let timestamp = 1641038400000; let date = new Date(timestamp).toLocaleString(); console.log(date); // '1/1/2022, 12:00:00 PM' ``` 这个例子中,我们首先定义了一个时间戳timestamp,然后使用new Date()方法将其转换成Date对象,并使用toLocaleString()方法将其转换日期字符串。最后我们打印了转换后的日期字符串。 3. 自定义日期字符串格式 有时候,我们需要自定义日期字符串格式以满足我们的需求,比如将日期字符串格式化为'2022年01月01日 12时00分00秒'。我们可以使用Date对象中的一些方法来实现该功能。 代码示例: ``` let timestamp = 1641038400000; let date = new Date(timestamp); let year = date.getFullYear(); let month = (date.getMonth() + 1).toString().padStart(2, '0'); let day = date.getDate().toString().padStart(2, '0'); let hours = date.getHours().toString().padStart(2, '0'); let minutes = date.getMinutes().toString().padStart(2, '0'); let seconds = date.getSeconds().toString().padStart(2, '0'); let formattedDate = `${year}年${month}月${day}日 ${hours}时${minutes}分${seconds}秒`; console.log(formattedDate); // '2022年01月01日 12时00分00秒' ``` 在这个例子中,我们首先定义了一个时间戳timestamp,然后使用new Date()方法将其转换成Date对象,并使用Date对象的一些方法获取日期字符串的年月日时分秒信息。在获取时分秒信息时,我们还应该对结果进行处理,确保它们是两位数的。最后,我们使用字符串模板将各个时间信息拼接成我们需要的格式化后的日期字符串,并打印到控制台。 总结 JavaScript中利用Date对象来实现时间戳日期字符串的相互转换很简单,只需要掌握几个基本的方法和技巧即可。同时,需要注意在进行日期字符串格式化时,应该对获取到的月、日、时、分、秒信息进行处理,确保它们都是两位数的。
评论 19
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

还是大剑师兰特

打赏一杯可口可乐

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值