Vue實現過濾器(filter)及應用場景

這是我參與更文挑戰的第 4 天,活動詳情查看:更文挑戰javascript

1. 簡單介紹

Vue.js 容許你自定義過濾器(filter),可被用於一些常見的文本格式化。 過濾器能夠用在兩個地方:雙花括號插值v-bind 表達式 (後者從 2.1.0+ 開始支持)。 過濾器應該被添加在 JavaScript 表達式的尾部,由「管道」符號指示:vue

<!-- 在雙花括號中 -->
{{ message | filter }}

<!-- 在 `v-bind` 中 -->
<div v-bind:msg="message | filter"></div>
複製代碼

過濾器函數總接收表達式的值做爲第一個參數。 在上述例子中,filter 過濾器函數將會收到 message 的值做爲第一個參數。java

1.1 過濾器能夠串聯

{{ message | filterA | filterB }}
複製代碼

在這個例子中,filterA 被定義爲接收單個參數的過濾器函數,表達式 message 的值將做爲參數傳入到函數中。而後繼續調用一樣被定義爲接收單個參數的過濾器函數 filterB,將 filterA 的結果傳遞到 filterB 中。vue-cli

1.2 過濾器是 JavaScript 函數能夠接收參數

{{ message | filterA('arg1', arg2) }}
複製代碼

filterA 被定義爲接收三個參數的過濾器函數。其中 message 的值做爲第一個參數,普通字符串 'arg1' 做爲第二個參數,表達式 arg2 的值做爲第三個參數。後端

2. vue-cli中定義全局過濾器

語法: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>
複製代碼

2.1 實際開發使用

  1. 全局過濾器常常會被在數據修飾上,一般咱們把處理函數給抽離出去,統一放在一個.js文件中。
// filter.js 文件

let filterPrice = (value) => {
	return '已收款' + value + '元'
}
let filterDate = (value) => {
    return value + '天'
}

export default {filterPrice,filterDate}
複製代碼
  1. 在main.js中 導入 上邊 filter.js文件 ,也能夠在任何組件中導入 filter.js這個文件,但對於全局過濾器來講,最好是在main.js中定義,導入的是一個對象,因此使用Object.keys()方法,獲得一個由key組成的數組,遍歷數據,讓key做爲全局過濾器的名字,後邊的是key對應的處理函數,這樣在任何一個組件中均可以使用全局過濾器了:
//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>
複製代碼

在這裏插入圖片描述

3. vue-cli中定義局部過濾器

// 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. 常見使用場景

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>
複製代碼

在這裏插入圖片描述

相關文章
相關標籤/搜索