这是我参与更文挑战的第 4 天,活动详情查看:更文挑战javascript
Vue.js 容许你自定义过滤器(filter),可被用于一些常见的文本格式化。 过滤器能够用在两个地方:双花括号插值和 v-bind 表达式 (后者从 2.1.0+ 开始支持)。 过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符号指示:vue
<!-- 在双花括号中 -->
{{ message | filter }}
<!-- 在 `v-bind` 中 -->
<div v-bind:msg="message | filter"></div>
复制代码
过滤器函数总接收表达式的值做为第一个参数。 在上述例子中,filter 过滤器函数将会收到 message 的值做为第一个参数。java
{{ message | filterA | filterB }}
复制代码
在这个例子中,filterA 被定义为接收单个参数的过滤器函数,表达式 message 的值将做为参数传入到函数中。而后继续调用一样被定义为接收单个参数的过滤器函数 filterB,将 filterA 的结果传递到 filterB 中。vue-cli
{{ message | filterA('arg1', arg2) }}
复制代码
filterA 被定义为接收三个参数的过滤器函数。其中 message 的值做为第一个参数,普通字符串 'arg1' 做为第二个参数,表达式 arg2 的值做为第三个参数。后端
语法:Vue.filter( filterName,( ) => { return // 数据处理结果 } ) eg:api
<div id="app">
<h3>{{userName | addName}}</h3>
</div>
<script> // 参数一:是过滤器的名字,也就是管道符后边的处理函数; // 参数二:处理函数,处理函数的参数同上 Vue.filter("addName",(value)=>{ return "my name is" + value }) let vm = new Vue({ el:"#app", data:{ userName:"小明" } }) </script>
复制代码
// filter.js 文件
let filterPrice = (value) => {
return '已收款' + value + '元'
}
let filterDate = (value) => {
return value + '天'
}
export default {filterPrice,filterDate}
复制代码
//main.js
//下边是2种导入方式,推荐第一种
import * as filters from './utils/filter/filter'
// import {filterPrice,filterDate} from './utils/filter/filter'
console.log(filters)
Object.keys(filters.default).forEach((item)=>{
Vue.filter(item,filters.default[item])
})
new Vue({
router,
store,
render: h => h(App),
}).$mount('#app')
复制代码
3. 在组件中使用 全局过滤器:数组
// test.vue
<template>
<div> <input type="text" v-model="filterCount" > <div>{{filterCount | filterPrice}}</div> <div>{{filterCount | filterDate}}</div> </div> </template>
<script> export default { data(){ return { filterCount:1500 } }, } </script>
复制代码
// test.vue
<template>
<div> <input type="text" v-model="filterCount" > <div class="filter">{{filterCount | changeCapitalLetter}}</div> </div> </template>
<script> export default { data(){ return { filterCount:'hello' } }, filters:{ changeCapitalLetter(value){ // value是输入框的内容,也是要显示的内容 if(value){ let str = value.toString(); // 获取英文,以空格分组把字符串转为数组,遍历每一项,第一项转为大写字母 let newArr = str.split(" ").map(ele=>{ return ele.charAt(0).toUpperCase() + ele.slice(1) }); return newArr.join(" ") // 数组转字符串 以空格输出。。。 } } }, } </script>
复制代码
4.1 格式日期(时间) 场景一:后端传的时间:2019-11-19T04:32:46Z 安装moment.jsmarkdown
// main.js
import moment from 'moment'
// 定义全局过滤器--时间格式化
Vue.filter('format',function(val,arg){
if(!val) return;
val = val.toString()
return moment(val).format(arg)
})
复制代码
// test.vue
<template>
<div class="filter">{{time | format('YYYY-MM-DD HH:MM:SS')}}</div>
</template>
<script> export default { data(){ return { time:'2019-11-19T04:32:46Z' } } } </script>
复制代码