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>
页面显示
vue全局过滤器配置
有时一个过滤器需要在项目中多次使用,此时可以将该过滤器定义为全局过滤器,全局过滤器在main.js下配置。
以时间过滤器为例,当为局部过滤器写为:
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); }
现在我们把它设置成全局过滤器
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) { //过滤代码}
- 然后定义一下过滤器:var timeform = vue.filter('timeform')
使用的时候和局部过滤器相同方式使用,直接{{ value | filter }} 即可
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。
发表评论