1. 程式人生 > >Vue自定義時間日期格式將毫秒數轉化為‘yyyy-MM-dd hh:mm:ss’

Vue自定義時間日期格式將毫秒數轉化為‘yyyy-MM-dd hh:mm:ss’

 新建 filter 資料夾,在filter新建index.js,建立全域性過濾器

//filter/index.js內容

import Vue from 'vue'

Vue.filter('date', function (dateTime, fmt) {
    var dateTime = new Date(dateTime);
    var o = {
        "M+": dateTime.getMonth() + 1,               //月份   
        "d+": dateTime.getDate(),                    //日   
        "h+": dateTime.getHours(),                   //小時   
        "m+": dateTime.getMinutes(),                 //分   
        "s+": dateTime.getSeconds(),                 //秒   
        "q+": Math.floor((dateTime.getMonth() + 3) / 3), //季度   
        "S": dateTime.getMilliseconds()             //毫秒   
    };

    if (/(y+)/.test(fmt)) {
        fmt = fmt.replace(RegExp.$1, (dateTime.getFullYear() + "").substr(4 - RegExp.$1.length));
    }
    for (var k in o) {
        if (new RegExp(`(${k})`).test(fmt)) {
            fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
        }
    }
    return fmt;
})

 記得在main.js中: 

import './filter/index.js'

這樣vue自定義的全域性過濾器就註冊完成了,如何使用呢?

1、直接在template中應用:

{{ 1536586255745 | date('yyyy-MM-dd hh:mm:ss')}}

2、在js中應用: