Vue中的過(guò)濾器(filter)詳解
官方文檔:https://cn.vuejs.org/v2/guide/filters.html
在官方文檔中,是這樣說(shuō)明的:可被用于一些常見的文本格式化,vue中過(guò)濾器的作用可被用于一些常見的文本格式化。(也就是修飾文本,但是文本內(nèi)容不會(huì)改變)
個(gè)人覺得稱它為加工車間會(huì)更加貼切一些,過(guò)濾器可以用來(lái)篩選出符合條件的,丟棄不符合條件的;加工車間既可以篩選,又可以對(duì)篩選出來(lái)的進(jìn)行加工。
過(guò)濾器使用位置
過(guò)濾器可以用在兩個(gè)地方:雙花括號(hào)插值和 v-bind 表達(dá)式 (后者從 2.1.0+ 開始支持)

示例:


<template>
<div class="test">
<div :id="rawId">{{rawId}}</div>
<!-- 以下v-bind可省略,即v-bind:id可簡(jiǎn)寫為:id -->
<div v-bind:id="rawId|filter_formatId">{{rawId|filter_formatId}}</div>
</div>
</template>
<script>
export default {
data() {
return {
rawId: 1
};
},
filters: {
filter_formatId(value) {
return value * 10;
}
}
};
</script>
<style lang="scss" scoped>
.test {
color: black;
}
</style>全局過(guò)濾器、局部過(guò)濾器
全局過(guò)濾器:
在main.js中寫入:

Vue.filter('filter_addPricePrefix', function (value) {
return "¥" + value;
})
局部過(guò)濾器:
在vue示例中寫入:

![]()
<template>
<div class="test">
<p>{{price}}</p>
<p>{{price | filter_addPricePrefix}}</p>
</div>
</template>
<script>
export default {
data() {
return {
price: 100
};
},
filters: {
filter_addPricePrefix(value) {
return "¥" + value;
}
}
};
</script>
<style lang="scss" scoped>
.test {
color: black;
}
</style>過(guò)濾器中傳入多個(gè)參數(shù):
過(guò)濾器是 JavaScript 函數(shù),因此可以接收參數(shù):
{{ message | filterA('arg1', arg2) }}這里,
filterA被定義為接收三個(gè)參數(shù)的過(guò)濾器函數(shù)。其中message的值作為第一個(gè)參數(shù),普通字符串'arg1'作為第二個(gè)參數(shù),表達(dá)式arg2的值作為第三個(gè)參數(shù)。


<template>
<div class="test">
<!-- 要過(guò)濾的數(shù)據(jù),永遠(yuǎn)是第一個(gè)參數(shù);通過(guò)filter函數(shù),傳遞的參數(shù),依次排在后面。 -->
<p>{{ new Date() | filter_dateFormat }}</p>
<p>{{ new Date() | filter_dateFormat('YYYY-MM-DD') }}</p>
<p>{{ new Date() | filter_dateFormat('YYYY-MM-DD', count) }}</p>
</div>
</template>
<script src="https://cdn.bootcss.com/moment.js/2.24.0/moment.js"></script>
<script>
export default {
data() {
return {
count: 10
};
},
filters: {
filter_dateFormat(date, format, count) {
return (
moment(date).format(format || "YYYY-MM-DD HH:mm:ss") +
(count ? " -- " + count : "")
);
}
}
};
</script>
<style lang="scss" scoped>
.test {
color: black;
}
</style>多個(gè)過(guò)濾器串聯(lián):
{{ message | filterA | filterB }}在這個(gè)例子中,
filterA被定義為接收單個(gè)參數(shù)的過(guò)濾器函數(shù),表達(dá)式message的值將作為參數(shù)傳入到函數(shù)中。然后繼續(xù)調(diào)用同樣被定義為接收單個(gè)參數(shù)的過(guò)濾器函數(shù)filterB,將filterA的結(jié)果傳遞到filterB中。


<template>
<div class="test">
<p>{{price}}</p>
<p>{{price | filter_addPricePrefix}}</p>
<p>{{price | filter_addPricePrefix |filter_addPriceSuffix}}</p>
</div>
</template>
<script>
export default {
data() {
return {
price: 100
};
},
filters: {
filter_addPricePrefix(value) {
return "¥" + value;
},
filter_addPriceSuffix(value) {
return value + "元";
}
}
};
</script>
<style lang="scss" scoped>
.test {
color: black;
}
</style>注意:
過(guò)濾器中通過(guò)this是獲取不到vue實(shí)例的!??!在其中發(fā)起http請(qǐng)求也會(huì)失敗,因此,為了獲取后臺(tái)數(shù)據(jù),我們可以在mounted中先獲取tableData,然后,把這個(gè)tableData作為過(guò)濾器的第二個(gè)參數(shù)進(jìn)行傳遞?。。?!


到此這篇關(guān)于Vue中的過(guò)濾器(filter)的文章就介紹到這了,更多相關(guān)Vue中的過(guò)濾器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
unplugin-vue-components解決命名沖突問(wèn)題
這篇文章主要介紹了unplugin-vue-components解決命名沖突問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
vue+moment實(shí)現(xiàn)倒計(jì)時(shí)效果
這篇文章主要為大家詳細(xì)介紹了vue+moment實(shí)現(xiàn)倒計(jì)時(shí)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08
手把手教你Vue3實(shí)現(xiàn)路由跳轉(zhuǎn)
Vue Router是Vue.js的官方路由器,它與Vue.js核心深度集成,使使用Vue.js構(gòu)建單頁(yè)應(yīng)用程序變得輕而易舉,下面這篇文章主要給大家介紹了關(guān)于Vue3實(shí)現(xiàn)路由跳轉(zhuǎn)的相關(guān)資料,需要的朋友可以參考下2022-08-08
vue項(xiàng)目中的支付功能實(shí)現(xiàn)(微信支付和支付寶支付)
本文主要介紹了vue項(xiàng)目中的支付功能實(shí)現(xiàn)(微信支付和支付寶支付),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01
解決keep-alive同一個(gè)組件不緩存問(wèn)題
這篇文章給大家介紹了如何解決keep-alive同一個(gè)組件不緩存問(wèn)題,文中通過(guò)代碼示例給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-02-02

