Vue如何引入全局過(guò)濾器
Vue引入全局過(guò)濾器
創(chuàng)建單獨(dú)的文件
加上時(shí)間過(guò)濾函數(shù)
將formatDate 暴露export 出來(lái)
// 時(shí)間戳轉(zhuǎn)時(shí)分秒 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); }; // 時(shí)間過(guò)濾 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過(guò)濾時(shí)間戳
<el-table :data="item.children" style="width: 100%"> <el-table-column prop="title" label="標(biāo)題"></el-table-column> <el-table-column prop="portName" label="上傳單位"></el-table-column> <el-table-column prop="createdTime" label="上傳時(shí)間"> <template slot-scope="scope">{{scope.row.createdTime | formatDate}}</template> </el-table-column> </el-table>
頁(yè)面顯示
vue全局過(guò)濾器配置
有時(shí)一個(gè)過(guò)濾器需要在項(xiàng)目中多次使用,此時(shí)可以將該過(guò)濾器定義為全局過(guò)濾器,全局過(guò)濾器在main.js下配置。
以時(shí)間過(guò)濾器為例,當(dāng)為局部過(guò)濾器寫為:
filters: { ? timeForm(val) { ? ? ? ? ? if (typeof (value) == "undefined" || value === null) return ""; ? ? ? ? ? let date = new Date(value); ? ? ? ? var y = date.getFullYear(); ? ? ? ? var m = date.getMonth() + 1; ? ? ? ? var d = date.getDate(); ? ? ? ? if (isNaN(y) && y != 0) { ? ? ? ? ? y = " "; ? ? ? ? } ? ? ? ? if (isNaN(m) && m != 0) { ? ? ? ? ? m = " "; ? ? ? ? } else { ? ? ? ? ? (m < 10 ? "0" + m : m); ? ? ? ? } ? ? ? ? if (isNaN(d) && d != 0) { ? ? ? ? ? d = " "; ? ? ? ? } else { ? ? ? ? ? (d < 10 ? "0" + d : d); ? ? ? ? } ? ? ? ? ? return y + "-" + m + "-" + d + " " + date.toTimeString().substr(0, 5); }
現(xiàn)在我們把它設(shè)置成全局過(guò)濾器
Vue.filter('timeForm', function (value) { ? if (typeof (value) == "undefined" || value === null) return ""; ? ? let date = new Date(value); ? var y = date.getFullYear(); ? var m = date.getMonth() + 1; ? var d = date.getDate(); ? if (isNaN(y) && y != 0) { ? ? y = " "; ? } ? if (isNaN(m) && m != 0) { ? ? m = " "; ? } else { ? ? (m < 10 ? "0" + m : m); ? } ? if (isNaN(d) && d != 0) { ? ? d = " "; ? } else { ? ? (d < 10 ? "0" + d : d); ? } ? return y + "-" + m + "-" + d + " " + date.toTimeString().substr(0, 5); }); var timeForm = Vue.filter('timeForm');
- 直接定義為:Vue.filter('timeForm', function (value) { //過(guò)濾代碼}
- 然后定義一下過(guò)濾器:var timeForm = Vue.filter('timeForm')
使用的時(shí)候和局部過(guò)濾器相同方式使用,直接{{ value | filter }} 即可
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue之?dāng)?shù)據(jù)交互實(shí)例代碼
本篇文章主要介紹了vue之?dāng)?shù)據(jù)交互實(shí)例代碼,vue中也存在像ajax和jsonp的數(shù)據(jù)交互,實(shí)現(xiàn)向服務(wù)器獲取數(shù)據(jù),有興趣的可以了解一下2017-06-06Vue.js實(shí)現(xiàn)簡(jiǎn)單ToDoList 前期準(zhǔn)備(一)
這篇文章主要介紹了Vue.js實(shí)現(xiàn)簡(jiǎn)單ToDoList的前期準(zhǔn)備,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12vue 實(shí)現(xiàn)路由跳轉(zhuǎn)時(shí)更改頁(yè)面title
今天小編就為大家分享一篇vue 實(shí)現(xiàn)路由跳轉(zhuǎn)時(shí)更改頁(yè)面title,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11vue計(jì)算屬性computed--getter和setter用法
這篇文章主要介紹了vue計(jì)算屬性computed--getter和setter用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01vue項(xiàng)目遇見(jiàn)事件冒泡該如何處理詳解
冒泡事件處理是由內(nèi)而外發(fā)生的,例如有兩個(gè)父子div,給他們分別寫上點(diǎn)擊事件,點(diǎn)擊子div先響應(yīng)的是子div,再是父div,下面這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目遇見(jiàn)事件冒泡該如何處理的相關(guān)資料,需要的朋友可以參考下2023-04-04在vue項(xiàng)目中,將juery設(shè)置為全局變量的方法
今天小編就為大家分享一篇在vue項(xiàng)目中,將juery設(shè)置為全局變量的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09vue打印插件vue-print-nb的實(shí)現(xiàn)代碼
這篇文章主要介紹了vue打印插件vue-print-nb的實(shí)現(xiàn),需要引入插件npm install vue-print-nb --save,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03vue?目錄樹(shù)的展開(kāi)與關(guān)閉的實(shí)現(xiàn)
Vue作為一款流行的前端框架,提供了一種數(shù)據(jù)驅(qū)動(dòng)的方式來(lái)實(shí)現(xiàn)目錄樹(shù),本文主要介紹了vue?目錄樹(shù)的展開(kāi)與關(guān)閉的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-11-11