vue過濾器filter的使用方法詳解
前言
vue允許自定義過濾器,我們通常用于對文本進行格式化一類的操作。如:將返回值 'abc' 設置為 'ABC' 顯示在頁面中;又或者,如果返回值為 'a' 頁面顯示 '張三',返回值為 'b' 頁面顯示 '李四'??傊?,對當前文本的各種操作,幾乎都可以用filter來解決。
注意:過濾器僅可以在兩個地方使用:1、花括號中;2、v-bind中;
// 在花括號中使用
<div>{{ message | msgFilter }}</div>
// 在v-bind中使用
<div v-bind:id="rawId | idFilter"></div>一、全局過濾器
vue項目中創(chuàng)建全局過濾器:在main.js中注冊全局過濾器,且必須放在vue實例創(chuàng)建之前。然后才可以在各個組件中使用。
//main.js
Vue.filter('filter1',function(value){
return value.chartAt(0).toUpperCase()+value.slice(1)
})
new Vue({
//.......
})二、局部過濾器
局部過濾器,在組件中定義,與data,created,methods等同級。
filters:{
filter1:function(value){
return value.chartAt(0).toUpperCase()+value.slice(1)
}
}三、多個過濾器串聯(lián)
我們在應用中,可以依次使用兩個或多個過濾器,每個過濾器的參數(shù)為上一次過濾器返回的結(jié)果。
<div> {{ message | filter1 | filter2 }} </div>在以上例子中,有兩個過濾器 filter1 和 filter2。首先會將 message 傳入 filter1 中進行第一次處理,然后再將 filter1 的處理結(jié)果,傳遞到 filter2 中進行第二次處理,最終,將filter2的處理結(jié)果渲染到頁面中。
四、過濾器添加參數(shù)
過濾器同樣是一個js函數(shù),因此可以添加參數(shù)。
<div> {{ message | filter1('param1','param2') }} </div>如上所示,filter1 有一個默認參數(shù) message ,我們自定義添加了兩個參數(shù) 'param1' 和 'param2',此時,在實際的過濾器函數(shù)中一共接收到三個參數(shù):message,'param1','param2';
filters:{
filter1:function(value,value1,value2){
console.log(value) // message變量的值
console.log(value1) // param1
console.log(value2) // param2
}
}五、過濾器 this 指向問題
filter過濾器中的this指向,并不是vue中的this,而是undefined;
因此,如果我們想要獲取data中的數(shù)據(jù),有兩種方法:1、改變this指向;2、傳參;
1、改變this 指向
<template>
<div class="file-bg"> {{ fileObj | typeFilter}} </div>
</template>
<script>
let that;
export default {
data(){
return{
fileObj:{type:'file'},
classObj:{file:'file-img'}
}
},
beforeCreate(){
that = this;
},
filters:{
typeFilter:function(obj){
console.log(that.classObj)
}
}
}
</script>2、傳參
<template>
<div class="file-bg"> {{ fileObj | typeFilter(classObj) }} </div>
</template>
<script>
export default {
data(){
return{
fileObj:{type:'file'},
classObj:{file:'file-img'}
}
},
filters:{
typeFilter:function(obj,classObj){
console.log(obj)
console.log(classObj)
}
}
}
</script>總結(jié)
到此這篇關于vue過濾器filter的使用方法的文章就介紹到這了,更多相關vue過濾器filter使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue3.0 vue.config.js 配置基礎的路徑問題
這篇文章主要介紹了vue3.0 vue.config.js 配置基礎的路徑問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10
Vue3結(jié)合TypeScript項目開發(fā)實踐總結(jié)
本文主要介紹了Vue3結(jié)合TypeScript項目開發(fā)實踐總結(jié),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09

