您现在的位置:首页 >> 前端 >> 内容

页面时间格式化的方法

时间:2017/10/23 16:27:12 点击:

  核心提示:有时候我们页面里常常会格式化时间,下面的就是一个简单的时间格式方法:function formatDate (date, fmt) {// 拼配fmt中的一个或多个y字符if (/(y+)/.test...

有时候我们页面里常常会格式化时间,下面的就是一个简单的时间格式方法:

function formatDate (date, fmt) {
    // 拼配fmt中的一个或多个y字符
    if (/(y+)/.test(fmt)) { // 匹配成功
        // RegExp.$1是匹配的y字符('yyyy'), 用时间的年份替换
        fmt = fmt.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length)); // substr() 方法可在字符串中抽取从 start 下标开始的指定数目的字符。
    }
    let o = {
        'M+': date.getMonth() + 1, // getMouth()获取的月份是从0~11,按习惯+1
        'd+': date.getDate(),
        'h+': date.getHours(),
        'm+': date.getMinutes(),
        's+': date.getSeconds()
    };
    for (let key in o) {
        if (new RegExp(`(${key})`).test(fmt)) {
            let str = o[key] + ''; // 时间对象对应的真实数字,转为字符串 + ‘’
            // 将字符串的MM dd hh mm 替换掉
            fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? str : padLeftZero(str));
        }
    }
    return fmt;
}
// 补0
function padLeftZero (str) {
    return ('00' + str).substr(str.length);
}
调用方法如下:formatDate (date, yyyy-MM-dd hh-mm);date为date对象,后面的字符串写自己想要的时间格式

作者:网络 来源:wangcuilin