过滤器
Vue.js 允许你自定义过滤器,可被用于一些常见的文本格式化。过滤器可以用在两个地方:双花括号插值和 v-bind
表达式 (后者从 2.1.0+ 开始支持)。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符号指示:
<!-- 在双花括号中 -->
<h3>现在的时间是:{{time | timeFormat}}</h3>
<!-- 过滤器实现(传参) -->
<h3>现在的时间是:{{time | timeFormat('YYYY_MM_DD') | mySlice}}</h3>
<!-- 在 `v-bind` 中 -->
<div v-bind:id="rawId | formatId"></div>
你可以在一个组件的选项中定义本地的过滤器:
filters:{
timeFormat(value, str='YYYY年MM月DD日 HH:mm:ss'){
return dayjs(value).format(str)
},
mySlice(value){
return value.slice(0,4)
}
}
或者在创建 Vue 实例之前全局定义过滤器:
Vue.filter('mySlice', function (value) {
return value.slice(0,4)
})
new Vue({ // ... })
注意:当全局过滤器和局部过滤器重名时,会采用局部过滤器。