JS 将时间戳转换为日期字符串 (5种方法 )
创始人
2025-01-09 15:05:29
0

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

在这里插入图片描述

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

文章目录

      • 方法1:使用 `Date` 构造函数
      • 方法2:格式化日期字符串
      • 方法3:使用国际化的API(Intl.DateTimeFormat)
      • 方法4:简易日期格式化库(如`moment.js`或`date-fns`)
      • 方法5:ES6模板字符串与解构


当然,以下是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、创思维怎么开挂透视...
截至目前!科乐辅助功能插件(辅... 截至目前!科乐辅助功能插件(辅助挂)一直有挂(实测开挂辅助平台)-哔哩哔哩1、科乐辅助功能插件系统规...
截至发稿!广西友乐免费辅助(辅... 截至发稿!广西友乐免费辅助(辅助挂)一直真的是有挂(科技开挂辅助软件)-哔哩哔哩1.广西友乐免费辅助...
据监测!微信小程序微乐辅助器下... 您好,微信小程序微乐辅助器下载这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302...
今年以来!胡乐胡乐辅助脚本可靠... 今年以来!胡乐胡乐辅助脚本可靠吗(辅助挂)果然真的是有挂(传授开挂辅助平台)-哔哩哔哩1、玩家可以在...
在玩家背景下!微信开发辅助工具... 在玩家背景下!微信开发辅助工具(辅助挂)一贯是有挂(传授开挂辅助脚本)-哔哩哔哩该软件可以轻松地帮助...
在玩家背景下!奇迹陕西靖边锅子... 在玩家背景下!奇迹陕西靖边锅子有没有技巧(辅助挂)其实是有挂(曝光开挂辅助平台)-哔哩哔哩一、奇迹陕...
截至目前!传送屋有挂吗(辅助挂... 截至目前!传送屋有挂吗(辅助挂)果然有挂(盘点开挂辅助平台)-哔哩哔哩1、传送屋有挂吗透视辅助简单,...
网友热议!葫芦娃七子连心攻略(... 网友热议!葫芦娃七子连心攻略(辅助挂)果然确实有挂(传授开挂辅助工具)-哔哩哔哩葫芦娃七子连心攻略软...
刚刚!雀友会广东潮汕bus(辅... 刚刚!雀友会广东潮汕bus(辅助挂)一直确实有挂(分享开挂辅助下载)-哔哩哔哩1、完成雀友会广东潮汕...