结合Vue.js官方文档
Vue.js 允许你自定义过滤器,可被用于一些常见的文本格式化。过滤器可以用在两个地方:双花括号插值和
v-bind
表达式 (后者从 2.1.0+ 开始支持)。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符号指示:<!-- 在双花括号中 --> {{ message | capitalize }} <!-- 在 `v-bind` 中 --> <div v-bind:id="rawId | formatId"></div>你可以在一个组件的选项中定义本地的过滤器:
filters: { capitalize: function (value) { if (!value) return '' value = value.toString() return value.charAt(0).toUpperCase() + value.slice(1) } }或者在创建 Vue 实例之前全局定义过滤器:
Vue.filter('capitalize', function (value) { if (!value) return '' value = value.toString() return value.charAt(0).toUpperCase() + value.slice(1) }) new Vue({ // ... })当全局过滤器和局部过滤器重名时,会采用局部过滤器。
注意:全局注册是是filter,没有s。组件过滤器是filters,有s。写的时候没有s也是不会报错的,但过滤器是没有效果的。
例子:
(1)下面这个例子用到了
capitalize
过滤器:(2)过滤器可以串联:
{{ message | filterA | filterB }}在这个例子中,
filterA
被定义为接收单个参数的过滤器函数,表达式message
的值将作为参数传入到函数中。然后继续调用同样被定义为接收单个参数的过滤器函数filterB
,将filterA
的结果传递到filterB
中。(3)过滤器是 JavaScript 函数,因此可以接收参数:
{{ message | filterA('arg1', arg2) }}这里,
filterA
被定义为接收三个参数的过滤器函数。其中message
的值作为第一个参数,普通字符串'arg1'
作为第二个参数,表达式arg2
的值作为第三个参数。(4)过滤器接收多个参数
{{ 'a','b' | filterB}}
filters:{
filterB:function(value,value2){
return value + '' + value2
}
}a和b分别作为参数传给filterB
个人理解与扩展
一、什么是过滤器filter
过滤器是对即将显示的数据做进一步的筛选处理,然后进行显示。
注意:过滤器并没有改变原来的数据,只是在原数据的基础上产生新的数据。
二、利用过滤器格式化时间形式
后台返回给前端的时间的UNIX时间戳:2017-12-24T14:32:20.000+0000
1、新建filter.js,写一个全局的fiter
const formatDateTime = (value) => { const date = new Date(value) const year = date.getFullYear() let month = date.getMonth() + 1 let day = date.getDate() let hours = date.getHours() let minutes = date.getMinutes() let seconds = date.getSeconds() if (month < 10) { month = '0' + month } if (day < 10) { day = '0' + day } if (hours < 10) { hours = '0' + hours } if (minutes === 0) { minutes = '00' } if (seconds < 10) { seconds = '0' + seconds } return year + '-' + month + '-' + day + ' ' + hours + ':' + minutes + ':' + seconds } export { formatDateTime }
2、引入和注册全局过滤器
import * as filters from './assets/javascript/filter'
Object.keys(filters).forEach(key => {
Vue.filter(key, filters[key])
})
3、在表格中展示的形式:
<el-table-column label="最近编辑时间" width="160" align="center"> <template slot-scope="scope">{{ scope.row.editTime | formatDateTime }}</template> </el-table-column>
4、结果,时间格式转换成功