欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue過(guò)濾器(filter)實(shí)現(xiàn)及應(yīng)用場(chǎng)景詳解

 更新時(shí)間:2021年06月15日 15:08:47   投稿:daisy  
在Vue中使用過(guò)濾器(Filters)來(lái)渲染數(shù)據(jù)是一種很有趣的方式,下面這篇文章主要給大家介紹了關(guān)于Vue過(guò)濾器(filter)實(shí)現(xiàn)及應(yīng)用場(chǎng)景的相關(guān)資料,需要的朋友可以參考下

1. 簡(jiǎn)單介紹

Vue.js 允許你自定義過(guò)濾器(filter),可被用于一些常見(jiàn)的文本格式化。

過(guò)濾器可以用在兩個(gè)地方:雙花括號(hào)插值和 v-bind 表達(dá)式 (后者從 2.1.0+ 開(kāi)始支持)。

過(guò)濾器應(yīng)該被添加在 JavaScript 表達(dá)式的尾部,由“管道”符號(hào)指示:

<!-- 在雙花括號(hào)中 -->
{{ message | filter }}

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

過(guò)濾器函數(shù)總接收表達(dá)式的值作為第一個(gè)參數(shù)。

在上述例子中,filter 過(guò)濾器函數(shù)將會(huì)收到 message 的值作為第一個(gè)參數(shù)。

1.1 過(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 中。

1.2 過(guò)濾器是 JavaScript 函數(shù)可以接收參數(shù)

{{ message | filterA('arg1', arg2) }}

filterA 被定義為接收三個(gè)參數(shù)的過(guò)濾器函數(shù)。其中 message 的值作為第一個(gè)參數(shù),普通字符串 'arg1' 作為第二個(gè)參數(shù),表達(dá)式 arg2 的值作為第三個(gè)參數(shù)。

2. vue-cli中定義全局過(guò)濾器

語(yǔ)法:Vue.filter( filterName,( ) => { return // 數(shù)據(jù)處理結(jié)果 } )

eg:

<div id="app">
  <h3>{{userName | addName}}</h3>
</div>
<script>
// 參數(shù)一:是過(guò)濾器的名字,也就是管道符后邊的處理函數(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 實(shí)際開(kāi)發(fā)使用

全局過(guò)濾器經(jīng)常會(huì)被在數(shù)據(jù)修飾上,通常我們把處理函數(shù)給抽離出去,統(tǒng)一放在一個(gè).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這個(gè)文件,但對(duì)于全局過(guò)濾器來(lái)說(shuō),最好是在main.js中定義,導(dǎo)入的是一個(gè)對(duì)象,所以使用Object.keys()方法,得到一個(gè)由key組成的數(shù)組,遍歷數(shù)據(jù),讓key作為全局過(guò)濾器的名字,后邊的是key對(duì)應(yīng)的處理函數(shù),這樣在任何一個(gè)組件中都可以使用全局過(guò)濾器了:

//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. 在組件中使用 全局過(guò)濾器:

// 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中定義局部過(guò)濾器

// 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. 常見(jiàn)使用場(chǎng)景

4.1 格式日期(時(shí)間)

場(chǎng)景一:后端傳的時(shí)間:2019-11-19T04:32:46Z

安裝moment.js

// main.js

import moment from 'moment'
// 定義全局過(guò)濾器--時(shí)間格式化
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過(guò)濾器(filter)實(shí)現(xiàn)及應(yīng)用場(chǎng)景的文章就介紹到這了,更多相關(guān)Vue過(guò)濾器(filter)實(shí)現(xiàn)應(yīng)用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Vue中的Props與Data細(xì)微差別

    詳解Vue中的Props與Data細(xì)微差別

    這篇文章主要介紹了詳解Vue中的Props與Data細(xì)微差別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • 詳解Vue3中響應(yīng)式的特殊處理

    詳解Vue3中響應(yīng)式的特殊處理

    這篇文章主要為大家詳細(xì)介紹了Vue3中響應(yīng)式的一些特殊處理,文中的示例代碼講解詳細(xì),對(duì)我們深入了解Vue3有一定的幫助,需要的可以參考一下
    2023-04-04
  • vue中axios實(shí)現(xiàn)數(shù)據(jù)交互與跨域問(wèn)題

    vue中axios實(shí)現(xiàn)數(shù)據(jù)交互與跨域問(wèn)題

    這篇文章主要介紹了vue中axios實(shí)現(xiàn)數(shù)據(jù)交互與跨域問(wèn)題,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2019-05-05
  • Vue3 插槽使用匯總

    Vue3 插槽使用匯總

    這篇文章主要給大家分享了Vue3的 插槽使用匯總,在 2.6.0中,vue 為具名插槽和作用于插槽引入了一個(gè)新的統(tǒng)一語(yǔ)法:v-slot。它取代了 slot 和 slot-scope 在新版中的應(yīng)用,下面就一起來(lái)看看文章的詳細(xì)內(nèi)容吧
    2021-12-12
  • Vue中Axios配置不同的baseURL,請(qǐng)求不同的域名接口方式

    Vue中Axios配置不同的baseURL,請(qǐng)求不同的域名接口方式

    這篇文章主要介紹了Vue中Axios配置不同的baseURL,請(qǐng)求不同的域名接口方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • Vue之讀取并解析ini文件中的內(nèi)容

    Vue之讀取并解析ini文件中的內(nèi)容

    這篇文章主要介紹了Vue之讀取并解析ini文件中的內(nèi)容,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 對(duì)Vue- 動(dòng)態(tài)元素屬性及v-bind和v-model的區(qū)別詳解

    對(duì)Vue- 動(dòng)態(tài)元素屬性及v-bind和v-model的區(qū)別詳解

    今天小編就為大家分享一篇對(duì)Vue- 動(dòng)態(tài)元素屬性及v-bind和v-model的區(qū)別詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • 解決Vue+Element ui開(kāi)發(fā)中碰到的IE問(wèn)題

    解決Vue+Element ui開(kāi)發(fā)中碰到的IE問(wèn)題

    今天小編就為大家分享一篇解決Vue+Element ui開(kāi)發(fā)中碰到的IE問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • vue 中固定導(dǎo)航欄的實(shí)例代碼

    vue 中固定導(dǎo)航欄的實(shí)例代碼

    今天小編就為大家分享一篇vue 中固定導(dǎo)航欄的實(shí)例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-11-11
  • vue圓形進(jìn)度條環(huán)形進(jìn)度條組件內(nèi)部顯示圖片示例

    vue圓形進(jìn)度條環(huán)形進(jìn)度條組件內(nèi)部顯示圖片示例

    這篇文章主要為大家介紹了vue圓形進(jìn)度條環(huán)形進(jìn)度條組件內(nèi)部顯示圖片示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11

最新評(píng)論