后端返回的时间前端格式化

在做项目中最近常有遇到后端返回时间字符串或是时间戳,前端根据需求展示成不同的文字,比如yyyy年MM月dd日,yyyy年MM月dd日 hh时mm分,yyyy-MM-dd hh:mm等不同格式,有如下格式化方法:

js 复制代码
function formatTime(time, fmt = 'yyyy年MM月dd日 hh时mm分') {
    if (!time) return ''

    let dt;
    if (typeof time === 'string') {
        dt = new Date(Date.parse(time)) || 0
    } else if (typeof time === 'number') {
        dt = new Date(time) || 0
    }

    const o = {
        'M+': dt.getMonth() + 1,
        'd+': dt.getDate(),
        'h+': dt.getHours(),
        'm+': dt.getMinutes(),
        's+': dt.getSeconds(),
        'q+': Math.floor((dt.getMonth() + 3) / 3),
        S: dt.getMilliseconds()
    }
    if (/(y+)/.test(fmt)) {
        fmt = fmt.replace(RegExp.$1, (dt.getFullYear() + '').substring(4 - RegExp.$1.length))
    }
    for (const k in o) {
        if (new RegExp('(' + k + ')').test(fmt)) {
            fmt = fmt.replace(
                RegExp.$1,
                RegExp.$1.length === 1 ? o[k] : ('00' + o[k]).substring(('' + o[k]).length)
            )
        }
    }
    return fmt
}

let originStr = '2024-04-02 08:34'
let strRes = formatTime(originStr, 'MM月dd日 hh时mm分')
console.log(strRes) // 04月02日 08时34分

let originStamp = 1712018040000
let stampRes = formatTime(originStamp, 'yyyy-MM-dd hh:mm:ss')
console.log(stampRes) // 2024-04-02 08:34:00

6Date.parse() 方法解析一个表示某个日期的字符串,并返回从 1970-1-1 00:00:00 UTC 到该日期对象(该日期对象的 UTC 时间)的毫秒数,如果该字符串无法识别,或者一些情况下,包含了不合法的日期数值(如:2015-02-31),则返回值为 NaN。

12 ~18 行在对象o 上依次存入了传入的时间字符串或是时间戳表示的月、日、时、分、秒、季度、毫秒 数字信息。

20 ~22 行处理年信息。第23 ~30 行先遍历对象o,如果给定的返回字符串模板中有年、月、日、时、分、秒、季度、毫秒中的项,就用对应的值替换掉字符串模板上的字符串,最后返回替换后的字符串。

还有一个点,两处if语句的判断条件分别是/(y+)/.test(fmt)new RegExp('(' + k + ')').test(fmt),这两个其中的.test()前面的正则都有一个捕获分组(),捕获分组 ()会把每个分组里匹配的值保存起来,因此在if语句内的RegExp.$1才能取得捕获分组()内匹配到的值。

使用这个formatTime方法时,传入的第一个参数需要在方法外处理好或者直接在方法内处理,第二个参数要按照o 对象中存年、月、日、时、分、秒、季度、毫秒的key一样给定字符串模板。

相关推荐
2501_94452100几秒前
rn_for_openharmony商城项目app实战-语言设置实现
javascript·数据库·react native·react.js·harmonyos
AdleyTales6 分钟前
vscode识别不了@提示找不到路径解决
前端·javascript·vscode
前端九哥29 分钟前
装个依赖把公司电脑干报废了?npm i 到底背着我干了啥?
前端·javascript
绝世唐门三哥1 小时前
工具函数-精准判断美东交易时间
前端·javascript·vue.js
踢球的打工仔1 小时前
typescript-null和undefined
前端·javascript·typescript
前端小蜗1 小时前
对不起,我很贱:老板还没催,我自己就统计《GitLab年度代码报告》
前端·javascript·人工智能
康一夏1 小时前
React面试题,useRef和普通变量的区别
前端·javascript·react.js
冴羽2 小时前
2025 年 HTML 年度调查报告公布!好多不知道!
前端·javascript·html
wszy18092 小时前
rn_for_openharmony_空状态与加载状态:别让用户对着白屏发呆
android·javascript·react native·react.js·harmonyos
程序员Agions2 小时前
别再只会 console.log 了!这 15 个 Console 调试技巧,让你的 Debug 效率翻倍
前端·javascript