使用 .toISOString() 方法生成当前时间的ISO格式字符串,解决UTC时区差问题

方法分析:

日常开发中,有时我们需要向后端传递的时间值可能并非一个时间对象,而是字符串格式。

例 1:[2023-08-16T08:07:25.577Z]

但是我们通过 new Date() 之后直接使用 .toString() 方法得到的却并非这种格式。

例 2:Tue Jan 01 2013 00:00:00 GMT+0800 (CST)

方法演示:

我们使用 .toISOString() 可以得到【例1】所示的时间格式,但是此方法返回的总是UTC时区的时间。

现在需要的就是解决时间差的问题,以下是解决方法的代码展示:

复制代码
// 获取当前时间ISO格式字符串
  getCurrentTime() {
    let datetime = new Date();
    let timezoneOffset = datetime.getTimezoneOffset() * 60000; // 获取当前时区与UTC的时间差(以毫秒为单位)
    let localDatetime = new Date(datetime - timezoneOffset); // 调整时间,得到当前时区时间
    let isoString = localDatetime.toISOString();
    return isoString;
  },
相关推荐
远方的小草3 分钟前
检索增强生成技术RAG
前端
haorooms7 分钟前
WebTransport 核心用法及身份验证和应用
前端
用户98236107902777 分钟前
Node.js 使用 adm-zip 操作 ZIP 文件指南
前端
yannick_liu9 分钟前
VUE2 + ElementUI 将Table数据导出为Excel文件——vue-json-excel
前端
哇哇哇哇9 分钟前
Vue3项目性能优化
前端
big tail18 分钟前
Windows本地Docker模拟前端项目发版
前端·windows·docker
学以智用23 分钟前
Vue3 状态管理库 Pinia 完整教程
前端·vue.js
北寻北爱24 分钟前
面试题-js篇
前端·javascript
harrain26 分钟前
vue3多个watch监听统一等待触发再执行后续逻辑的处理方案
前端·javascript·vue.js
miss27 分钟前
Vue3 + AI Agent 前端开发实战:一个 前端开发工程师的转型记录
前端