首页 > web前端 > js教程 > 正文

js date对象格式化日期

冰川箭仙
发布: 2025-11-25 16:15:06
原创
516人浏览过
JavaScript的Date对象通过getFullYear、getMonth等方法手动拼接可实现YYYY-MM-DD HH:mm:ss格式;简化版仅保留日期部分;toISOString适用于UTC时间处理;Intl.DateTimeFormat支持国际化输出,推荐用于本地化场景。

js date对象格式化日期

JavaScript 的 Date 对象本身不提供像其他语言那样的内置格式化字符串方法,但可以通过其提供的方法来获取年、月、日、时、分、秒等信息,并拼接成所需的日期格式。下面介绍几种常用方式来格式化日期。

1. 手动格式化常用日期格式

使用 Date 对象的方法,如 getFullYear()getMonth()(注意:月份从 0 开始)、getDate() 等,手动拼接成需要的格式。

例如,格式化为 YYYY-MM-DD HH:mm:ss

function formatDate(date) {
  const year = date.getFullYear();
  const month = String(date.getMonth() + 1).padStart(2, '0'); // 月份从0开始,需+1
  const day = String(date.getDate()).padStart(2, '0');
  const hour = String(date.getHours()).padStart(2, '0');
  const minute = String(date.getMinutes()).padStart(2, '0');
  const second = String(date.getSeconds()).padStart(2, '0');

  return `${year}-${month}-${day} ${hour}:${minute}:${second}`;
}

// 使用示例
const now = new Date();
console.log(formatDate(now)); // 输出:2025-04-05 14:30:25
登录后复制

2. 格式化为 YYYY-MM-DD

如果只需要日期部分,可以简化函数:

function toDateString(date) {
  const year = date.getFullYear();
  const month = String(date.getMonth() + 1).padStart(2, '0');
  const day = String(date.getDate()).padStart(2, '0');
  return `${year}-${month}-${day}`;
}
console.log(toDateString(new Date())); // 输出:2025-04-05
登录后复制

3. 使用 toISOString() 处理 UTC 时间

如果处理的是标准时间或需要 ISO 格式,可以直接使用 toISOString(),然后截取所需部分:

Levity
Levity

AI帮你自动化日常任务

Levity 206
查看详情 Levity
const date = new Date();
const isoDate = date.toISOString(); // 返回:2025-04-05T06:30:25.123Z
const simpleDate = isoDate.split('T')[0]; // 只取日期部分:2025-04-05
登录后复制

这种方式适合用于保存或传输数据,但注意是 UTC 时间。

4. 使用 Intl.DateTimeFormat(推荐国际化场景)

更现代的方式是使用 Intl.DateTimeFormat,支持本地化和灵活格式:

const date = new Date();
const formatter = new Intl.DateTimeFormat('zh-CN', {
  year: 'numeric',
  month: '2-digit',
  day: '2-digit',
  hour: '2-digit',
  minute: '2-digit',
  second: '2-digit',
  hour12: false
});

console.log(formatter.format(date)); // 输出:2025/04/05 14:30:25(可根据 locale 调整)
登录后复制

可将分隔符替换为短横线:

formatter.format(date).replace(/\//g, '-'); // 2025-04-05 14:30:25
登录后复制
基本上就这些常见用法。根据项目需求选择手动拼接、ISO 方法或 Intl 国际化格式。简单场景用第一种最直接。

以上就是js date对象格式化日期的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号