Vue過濾器(filter)實現(xiàn)及應(yīng)用場景詳解
1. 簡單介紹
Vue.js 允許你自定義過濾器(filter),可被用于一些常見的文本格式化。
過濾器可以用在兩個地方:雙花括號插值和 v-bind 表達式 (后者從 2.1.0+ 開始支持)。
過濾器應(yīng)該被添加在 JavaScript 表達式的尾部,由“管道”符號指示:
<!-- 在雙花括號中 --> {{ message | filter }} <!-- 在 `v-bind` 中 --> <div v-bind:msg="message | filter"></div>
過濾器函數(shù)總接收表達式的值作為第一個參數(shù)。
在上述例子中,filter 過濾器函數(shù)將會收到 message 的值作為第一個參數(shù)。
1.1 過濾器可以串聯(lián)
{{ message | filterA | filterB }}
在這個例子中,filterA 被定義為接收單個參數(shù)的過濾器函數(shù),表達式 message 的值將作為參數(shù)傳入到函數(shù)中。然后繼續(xù)調(diào)用同樣被定義為接收單個參數(shù)的過濾器函數(shù) filterB,將 filterA 的結(jié)果傳遞到 filterB 中。
1.2 過濾器是 JavaScript 函數(shù)可以接收參數(shù)
{{ message | filterA('arg1', arg2) }}
filterA 被定義為接收三個參數(shù)的過濾器函數(shù)。其中 message 的值作為第一個參數(shù),普通字符串 'arg1' 作為第二個參數(shù),表達式 arg2 的值作為第三個參數(shù)。
2. vue-cli中定義全局過濾器
語法:Vue.filter( filterName,( ) => { return // 數(shù)據(jù)處理結(jié)果 } )
eg:
<div id="app"> <h3>{{userName | addName}}</h3> </div> <script> // 參數(shù)一:是過濾器的名字,也就是管道符后邊的處理函數(shù); // 參數(shù)二:處理函數(shù),處理函數(shù)的參數(shù)同上 Vue.filter("addName",(value)=>{ return "my name is" + value }) let vm = new Vue({ el:"#app", data:{ userName:"小明" } }) </script>
2.1 實際開發(fā)使用
全局過濾器經(jīng)常會被在數(shù)據(jù)修飾上,通常我們把處理函數(shù)給抽離出去,統(tǒng)一放在一個.js文件中。
// filter.js 文件 let filterPrice = (value) => { return '已收款' + value + '元' } let filterDate = (value) => { return value + '天' } export default {filterPrice,filterDate}
在main.js中 導(dǎo)入 上邊 filter.js文件 ,也可以在任何組件中導(dǎo)入 filter.js這個文件,但對于全局過濾器來說,最好是在main.js中定義,導(dǎo)入的是一個對象,所以使用Object.keys()方法,得到一個由key組成的數(shù)組,遍歷數(shù)據(jù),讓key作為全局過濾器的名字,后邊的是key對應(yīng)的處理函數(shù),這樣在任何一個組件中都可以使用全局過濾器了:
//main.js //下邊是2種導(dǎo)入方式,推薦第一種 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>
3. vue-cli中定義局部過濾器
// 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>
4. 常見使用場景
4.1 格式日期(時間)
場景一:后端傳的時間:2019-11-19T04:32:46Z
// 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>
總結(jié)
到此這篇關(guān)于Vue過濾器(filter)實現(xiàn)及應(yīng)用場景的文章就介紹到這了,更多相關(guān)Vue過濾器(filter)實現(xiàn)應(yīng)用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue中axios實現(xiàn)數(shù)據(jù)交互與跨域問題
這篇文章主要介紹了vue中axios實現(xiàn)數(shù)據(jù)交互與跨域問題,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下2019-05-05Vue中Axios配置不同的baseURL,請求不同的域名接口方式
這篇文章主要介紹了Vue中Axios配置不同的baseURL,請求不同的域名接口方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07對Vue- 動態(tài)元素屬性及v-bind和v-model的區(qū)別詳解
今天小編就為大家分享一篇對Vue- 動態(tài)元素屬性及v-bind和v-model的區(qū)別詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08解決Vue+Element ui開發(fā)中碰到的IE問題
今天小編就為大家分享一篇解決Vue+Element ui開發(fā)中碰到的IE問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09vue圓形進度條環(huán)形進度條組件內(nèi)部顯示圖片示例
這篇文章主要為大家介紹了vue圓形進度條環(huán)形進度條組件內(nèi)部顯示圖片示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-11-11