溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

vue中內(nèi)置過濾器怎么用

發(fā)布時間:2021-08-10 12:48:58 來源:億速云 閱讀:106 作者:小新 欄目:web開發(fā)

小編給大家分享一下vue中內(nèi)置過濾器怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

前言

vue中過濾器filters的作用是什么?

過濾器是一個通過輸入數(shù)據(jù),能夠及時對數(shù)據(jù)進(jìn)行處理并返回一個數(shù)據(jù)結(jié)果的簡單函數(shù)。Vue有很多很便利的過濾器,可以參考官方文檔。

能夠幫我們處理快速一些數(shù)據(jù)的格式----format數(shù)據(jù)格式化處理。

語法也很簡單

{{ message | Filter }}
  • message: 要格式化的數(shù)據(jù)

  • Filter: 對數(shù)據(jù)格式化的方法

鏈?zhǔn)竭^濾

VueJs允許你鏈?zhǔn)秸{(diào)用過濾器,簡單的來說,就是一個過濾器的輸出成為下一個過濾器的輸入,然后再次過濾。接下來,我們可以想象一個比較簡答的例子,使用了Vue的 filterBy + orderBy 過濾器來過濾所有商品products。過濾出來的產(chǎn)品是屬于電器類商品,并且按電器字母排序。

filterBy過濾器 : 過濾器的值必須是一個數(shù)組,filterBy + 過濾條件。過濾條件是:‘string || function' + in ‘optionKeyName'

orderBy過濾器 : 過濾器的值必須是一個數(shù)組,orderBy + 過濾條件。過濾條件是:‘string || array ||function' + ‘order ≥ 0 為升序 || order < 0 為降序'

接下來,我們可以看下第二個例子:我們有一個商品數(shù)組products,我們希望遍歷這個數(shù)組,并把他們打印成一張清單,這個用v-for很容易實現(xiàn)。

<li v-for="product in products">
 {{ product.name | capitalize }} - {{ product.price | currency }}
</li>

capitalize過濾器 : 將輸入的字符串首字母轉(zhuǎn)換成大寫字母的過濾器。currency過濾器 : 將輸入的數(shù)字轉(zhuǎn)換成現(xiàn)金的過濾器。可以跟上貨幣符號(默認(rèn)$)和保留的小數(shù)位(默認(rèn)2)。

利用上面的兩個過濾器,能夠很好的把一個json數(shù)組的商品清單格式化成通熟易懂的商品價格清單。

如果只想要電器類商品,可以在v-for上加過濾條件:

<li v-for="product in products | filterBy 'electronics' in 'category' ">
 {{ product.name | capitalize }} - {{ product.price | currency }}
</li>

上面的例子,就是用filterBy 過濾在 'category'中含有'electronics' 關(guān)鍵字的列表,返回的列表就是只含有 'electronics' 關(guān)鍵字的列表。

如果想要多個搜索條件:

<li v-for="product in products | filterBy 'electronics' in 'category' 'name' ">
 {{ product.name | capitalize }} - {{ product.price | currency }}
</li>

上面的例子,就是用filterBy 過濾在 'category' 和 'name' 中含有'electronics' 關(guān)鍵字的列表。

最后我們還需要將這個列表用字母進(jìn)行排序。我們可以在 filterBy 過濾器的基礎(chǔ)上,鏈?zhǔn)秸{(diào)用orderBy 過濾器。

<ul>
 <li v-for="product in products
   | filterBy 'electronics' in 'category'
   | orderBy 'name' "
 >
  {{ product.name | capitalize }} - {{ product.price | currency }}
 </li>
</ul>

orderBy 的排序方式默認(rèn)是升序,如果想要降序,只需要加一個小于0的參數(shù):

<li v-for="product in products
  | filterBy 'electronics' in 'category'
  | orderBy 'name' -1 "
>

下面看看vue自帶過濾器有哪些,并附帶小示例。最后記得看看如果自定義過濾器哦!

vue自帶的過濾器

capitalize(首字母大寫)

<div class="test">
 {{message | capitalize}}
</div>

<script type="text/javascript">
var myVue = new Vue({
 el: ".test",
 data: {
 message: "javan"
 }
})
</script>

上面代碼輸出:Javan

uppercase(全部大寫)

// 初始message:abc

{{message | uppercase}}

// 上面代碼輸出:ABC

lowercase(全部小寫)

// 初始message:ABC

{{message | lowercase}}

// 上面代碼輸出:abc

currency(輸出金錢以及小數(shù)點(diǎn))

<div class="test">
 {{message | currency}} // 輸出$520.13
 {{message | currency '&yen;' "2"}} //輸出 $520.13
</div>
<script type="text/javascript">
 var myVue = new Vue({
 el: ".test",
 data: {
  message: "520.1314"
 }
 })
</script>

第一個參數(shù) {String} [貨幣符號] - 默認(rèn)值: '$'
第二個參數(shù) {Number} [小數(shù)位] - 默認(rèn)值: 2

pluralize(變復(fù)數(shù))

如果只有一個參數(shù),復(fù)數(shù)形式只是簡單地在末尾添加一個 “s”。如果有多個參數(shù),參數(shù)被當(dāng)作一個字符串?dāng)?shù)組,對應(yīng)一個、兩個、三個…復(fù)數(shù)詞。如果值的個數(shù)多于參數(shù)的個數(shù),多出的使用最后一個參數(shù)。

<div class="test">
 {{message}} {{message | pluralize 'item'}} 輸出: 1 item
 <ul v-for="item in lili">
 <li>
  {{item}} {{item | pluralize 'item'}}
  輸出: 1 item 2 items 3 items
 </li>
 </ul>

 <ul v-for="item in lili">
 <li>
  {{item}} {{item | pluralize 'st' 'rd'}}
  輸出: 1 st 2 rd 3 rd
 </li>
 </ul>

 <ul v-for="item in man">
 <li>
  {{item}} {{item | pluralize 'item'}}
  輸出: 1 item 2 items 3 items
 </li>
 </ul>

 <ul v-for="item in man">
 <li>
  {{item}} {{item | pluralize 'st' 'rd'}}
  輸出: 1 st 2 rd 3 rd
 </li>
 </ul>
</div>
<script type="text/javascript">
 var myVue = new Vue({
 el: ".test",
 data: {
  message: 1,
  lili: [1,2,3],
  man: {
  name1: 1,
  name2: 2,
  name3: 3
  }
 }
 })
</script>

debounce(事件延時)

1) 限制: 需在@里面使用
2) 參數(shù):{Number} [wait] - 默認(rèn)值: 300
3) 功能:包裝處理器,讓它延遲執(zhí)行 x ms, 默認(rèn)延遲 300ms。包裝后的處理器在調(diào)用之后至少將延遲 x ms, 如果在延遲結(jié)束前再次調(diào)用,延遲時長重置為 x ms。

<div class="test">
 <button id="btn" @click="doSomeThing | debounce 10000">點(diǎn)擊我</button>
</div>
<script type="text/javascript">
 var myVue = new Vue({
 el: ".test",
 methods: {
  doSomeThing: function () {
  // do something
  }
 }
 })
</script>

limitBy(排序)

1) 限制:需在v-for(即數(shù)組)里面使用

第一個參數(shù):{Number} 取得數(shù)量

第二個參數(shù):{Number} 偏移量

<div class="test">
 <ul v-for="item in lili | limitBy 10">
 <li>{{item}}</li>
 輸出1 2 3 4 5 6 7 8 9 10
 </ul>
 <ul v-for="item in lili | limitBy 10 3">
 <li>{{item}}</li>
 輸出 4 5 6 7 8 9 10 11 12 13
 </ul>
</div>
<script type="text/javascript">
 var myVue = new Vue({
 el: ".test",
 data: {
  lili: [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]
 }
 })
</script>

filterBy(過濾)

1) 限制:需在v-for(即數(shù)組)里面使用

第一個參數(shù): {String | Function} 需要搜索的字符串

第二個參數(shù): in (可選,指定搜尋位置)

第三個參數(shù): {String} (可選,數(shù)組格式)

<div class="test">
 <ul v-for="item in lili | filterBy 'o' ">
 <li>{{item}}</li>
 輸出oi oa lo ouo oala
 </ul>
 <ul v-for="item in man | filterBy 'l' in 'name' ">
 <li>{{item.name}}</li>
 輸出lily lucy
 </ul>
 <ul v-for="item in man | filterBy 'l' in 'name' 'dada' ">
 <li>{{item.name+"+"+item.dada}}</li>
 輸出lily+undefined lucy+undefined undefined+lsh
 </ul>
</div>
<script type="text/javascript">
var myVue = new Vue({
 el: ".test",
 data: {
 lili: ["oi", "oa", "ll", "lo" ,"ouo" ,"kk" ,"oala"],
 man: [ //此處注意man是數(shù)組,不是對象
 {name: "lily"},
 {name: "lucy"},
 {name: "oo"},
 {dada: "lsh"},
 {dada: "ofg"}
 ]
 }
})
</script>

orderBy(排序)

1) 限制:需在v-for(即數(shù)組)里面使用

第一個參數(shù): {String | Array | Function} 需要搜索的字符串

第二個參數(shù): {String} 可選參數(shù) order 決定結(jié)果升序(order >= 0)或降序(order < 0),默認(rèn)是升序

<div class="test">
 遍歷數(shù)組
 <ul v-for="item in lili | orderBy 'o' 1">
 <li>{{item}}</li>
 輸出kk ll oi
 </ul>
 <ul v-for="item in lili | orderBy 'o' -1">
 <li>{{item}}</li>
 輸出oi ll kk
 </ul>
 遍歷含對象的數(shù)組
 <ul v-for="item in man | orderBy 'name' 1">
 <li>{{item.name}}</li>
 輸出Bruce Chuck Jackie
 </ul>
 <ul v-for="item in man | orderBy 'name' -1">
 <li>{{item.name}}</li>
 輸出Jackie Chuck Bruce
 </ul>
 使用函數(shù)排序
 <ul v-for="item in man | orderBy ageByTen">
 <li>{{item.name}}</li>
 輸出Bruce Chuck Jackie
 </ul>
</div>
<script type="text/javascript">
 var myVue = new Vue({
 el: ".test",
 data: {
  lili: ["oi", "kk", "ll"],
  man: [ //此處注意man是數(shù)組,不是對象
  {
  name: 'Jackie',
  age: 62
  },
  {
  name: 'Chuck',
  age: 76
  },
  {
  name: 'Bruce',
  age: 61
  }
 ]
 },
 methods: {
  ageByTen: function () {
  return 1;
  }
 }
 })
</script>

自定義過濾器

<div class="test">
 {{'2018-11-16 18:12:15'|formatDate}}
</div>
<script type="text/javascript">
 var myVue = new Vue({
 el: ".test",
 methods: {
 },
 filters:{
  formatDate (val) {
  return moment(val).format('YYYY-MM-DD');
  // 這里用到了moment.js
  }
 }
 })
</script>

以上是“vue中內(nèi)置過濾器怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

vue
AI