Vue引入全局過濾器

創建單獨的文件

在這裏插入圖片描述

加上時間過濾函數

將formatDate 暴露export 出來

// 時間戳轉時分秒
function getformatDate (date, fmt) {
  if (/(y+)/.test(fmt)) {
      fmt = fmt.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length));
  }
  let o = {
      'M+': date.getMonth() + 1,
      'd+': date.getDate(),
      'h+': date.getHours(),
      'm+': date.getMinutes(),
      's+': date.getSeconds()
  };
  for (let k in o) {
      if (new RegExp(`(${k})`).test(fmt)) {
          let str = o[k] + '';
          fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? str : padLeftZero(str));
      }
  }
  return fmt;
};

function padLeftZero (str) {
  return ('00' + str).substr(str.length);
};

 // 時間過濾
 export function formatDate(time) {
  return getformatDate(new Date(time), "yyyy-MM-dd hh:mm");
}

在main.js中全局引入

import * as filters from './filters' // global filters

// register global utility filters.
Object.keys(filters).forEach(key => {
  Vue.filter(key, filters[key])
})

在組件中使用formatDate過濾時間戳

          <el-table :data="item.children" style="width: 100%">
            <el-table-column prop="title" label="標題"></el-table-column>
            <el-table-column prop="portName" label="上傳單位"></el-table-column>
            <el-table-column prop="createdTime" label="上傳時間">
              <template slot-scope="scope">{{scope.row.createdTime | formatDate}}</template>
            </el-table-column>
          </el-table>

頁面顯示

在這裏插入圖片描述


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章