vue中的过滤器,主要用于文本的格式化,或者数组数据的过滤与排序等。其本质是一个函数,它不改变原始数据,只是对数据进行加工处理后返回过滤后的数据。过滤器可以用在两个地方:双花括号插值和v-bind表达式,使用时通过管道符 | 添加到表达式的尾部使用。语法如下:
- 花括号
<div>{{ Id | formatId }}</div>
- v-bind
<div v-bind:id="Id | formatId"></div>
如下例子:通过filters选项,定义了一个叫filterName的过滤器,它默认管道符前面的值作为第一个参数,filterName会返回一个格式化后的字符串。
<template>
<div class="home_box">
<p>{{ this.name | filterName }}</p>
</div>
</template>
<script>
export default {
name: 'Home',
filters: {
filterName(value) {
return `${value}-过滤器`
}
},
data() {
return {
name: '王五'
}
}
}
</script>
首先在src目录下新建一个filters.js文件,用来装所有的filter。然后在main.js中导入,挂载到vue实例上,即可在所有组件中使用。
- filters.js
/**
* @description 首字母大写
*/
export const capitalize = (value) => {
if (!value) return ''
value = value.toString()
return value.charAt(0).toUpperCase() + value.slice(1)
}
/**
* @description 双倍
*/
export const double = (value) => {
return value * 2
}
- main.js
import Vue from 'vue'
import ElementUI from 'element-ui'
import App from './App.vue'
import * as filterEnum from '@/utils/filters.js'
Vue.use(ElementUI)
Object.keys(filterEnum).forEach(key => {
Vue.filter(key, filterEnum[key])
})
const app = new Vue({
render: h => h(App)
})
app.$mount('#app')
filter也是可以传递参数的,如下例子,过滤器filterFn接收了三个参数。其中 message 的值作为第一个参数,arg1 作为第二个参数,arg2 作为第三个参数。
<div>{{ message | filterFn('arg1', 'arg2') }}</div>
过滤器可以串联,如下例子,filterA 被定义为接收单个参数的过滤器函数,表达式 message 的值将作为参数传入到函数中。然后继续调用同样被定义为接收单个参数的过滤器函数 filterB,将 filterA 的结果传递到 filterB。
<div>{{ message | filterA | filterB }}</div>
过滤器使用场景很多。比如:
- 后端返回了一个状态,值为false/true或0/1,需要你转成文字是和否
- 数字/日期需要格式化等
如下例子,根据result的值,显示不同的文字。
<template>
<div class="home_box">
<h1>{{ result | checkcCloudless }}</h1>
</div>
</template>
<script>
export default {
name: 'Home',
filters: {
checkcCloudless(value) {
return value ? '晴天' : '阴天'
}
},
data() {
return {
result: false
}
}
}
</script>
- computed:
- 主要用来逻辑运算,防止模板过重
- 有缓存 只有依赖的其他数据项变化它才变
- 监听,有get和set两个方法,get必须return
- 只有依赖的其他数据项变化它才变
- 在模板外面直接this.使用
- filter:
- 主要用做数据格式化的处理
- 无法缓存 每次渲染都会执行
- 定义方式的区别,filter可以通过filters和vue.filter定义
- 在模板外面使用必须用this.$options.filters['filter名字']