" />

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

編寫 Vue v-for 循環(huán)的 7 種方式

 更新時間:2021年12月30日 11:21:14   作者:耀_  
這篇文章主要分享可編寫 Vue v-for 循環(huán)的 7 種方式,在Vue中,基本上每個項(xiàng)目都會用到v-for循環(huán)。它們允許你在模板代碼中編寫for循環(huán),接下來一起看看下面文章的詳細(xì)介紹吧

這在碰到諸如以下情況時特別好用:

  • 渲染數(shù)組或列表
  • 遍歷對象屬性

在Vue中v-for循環(huán)最基本的用法是這樣的:

<ul>
  <li v-for='product in products'>
    {{ product.name }}
  </li>
</ul>


但是,在本文中,我們將介紹一些超棒的方法,可以使你的v-for代碼更加精確、可預(yù)測和高效。

讓我們開始吧。

1. 始終在v-for循環(huán)中使用key

首先,我們討論的是大多數(shù)Vue開發(fā)人員已經(jīng)知道的常見最佳實(shí)踐——在v-for循環(huán)中使用:key。通過設(shè)置唯一的鍵屬性,可以確保組件按期望的方式工作。

如果我們不使用:key,Vue將使DOM盡可能高效。這可能會導(dǎo)致v-for元素出現(xiàn)亂序或其他不可預(yù)測的行為。

如果我們對每個元素都有唯一的鍵引用,那么就可以更好地預(yù)測如何操縱DOM。

<ul>
  <li 
    v-for='product in products'
    :key='product._id'  
  >
    {{ product.name }}
  </li>
</ul>


2. 在一定范圍內(nèi)使用v-for循環(huán)

雖然大多數(shù)時候v-for用于循環(huán)數(shù)組或?qū)ο?,但也有我們只想迭代特定次?shù)的情況。

例如,假設(shè)我們正在為在線商店創(chuàng)建分頁系統(tǒng),并且我們只想每頁顯示10個產(chǎn)品。使用變量來跟蹤當(dāng)前頁碼,就可以像這樣處理分頁。

<ul>
  <li v-for='index in 10' :key='index'>
    {{ products[page * 10 + index] }}
  </li>
</ul>


3. 避免在循環(huán)中使用v-if

一個超常見的錯誤是使用v-if來過濾v-for循環(huán)的數(shù)據(jù)。

雖然看上去直觀了,但這會導(dǎo)致一個巨大的性能問題——VueJS將優(yōu)先v-for于v-if指令。

這意味著組件將遍歷每個元素,然后再檢查v-if條件以查看是否應(yīng)該呈現(xiàn)。

如果你將v-if與v-for一起使用,無論條件是什么,都將遍歷數(shù)組的每一項(xiàng)。

// 不好的做法!
<ul>
  <li 
    v-for='product in products' 
    :key='product._id' 
    v-if='product.onSale'
  >
    {{ product.name }}
  </li>
</ul>


那么問題是什么?

假設(shè)products數(shù)組有數(shù)千個項(xiàng),但想要渲染的只有3個在售產(chǎn)品。

每次重新渲染時,即使出售的3種產(chǎn)品根本沒有改變,Vue也必須遍歷這數(shù)千個項(xiàng)。

必須盡量避免結(jié)合使用v-if與v-for的情況。

接下來介紹兩個替代方法。

4. 使用computed屬性或方法

為了避免上述問題,我們應(yīng)該在模板中進(jìn)行迭代之前過濾數(shù)據(jù)。有兩種非常相似的方法可以做到:

  • 使用computed屬性
  • 使用過濾方法

隨你選擇,下面讓我們快速介紹這兩個方法。

首先,我們只需要設(shè)置一個computed屬性。為了獲得與之前的v-if相同的功能,代碼看起來像這樣。

<template>
  <ul>
    <li v-for="products in productsOnSale" :key="product._id">
      {{ product.name }}
    </li>
  </ul>
</template>

<script>
  export default {
    data () {
      return {
        products: []
      }
    },
    computed: {
      productsOnSale: function () {
        return this.products.filter(product => product.onSale)
      }
    }
  }
</script>

這樣的好處是:

  • 數(shù)據(jù)屬性只會在依賴項(xiàng)發(fā)生變化時重新評估
  • 模板只遍歷在售的產(chǎn)品,而不是每一個產(chǎn)品

使用過濾方法的代碼幾乎相同,但使用方法會改變訪問模板內(nèi)值的方式。但是,如果我們希望能夠?qū)⒆兞總鬟f給過濾過程,那么就應(yīng)該選擇方法這條路。

<template>
  <ul>
    <li v-for="products in productsOnSale(50))" :key="product._id">
      {{ product.name }}
    </li>
  </ul>
</template>

<script>
  export default {
   data () {
    return {
     products: []
    }
   },
   methods: {
    productsOnSale (maxPrice) {
     return this.products.filter(product => product.onSale && product.price < maxPrice)
    }
   }
  }
</script>


5. 或者在循環(huán)外包一層元素

在決定是否完全渲染列表時,你可能還是想要將v-forv-if結(jié)合起來。

例如,如果我們只想在用戶登錄時呈現(xiàn)產(chǎn)品列表怎么辦。

錯誤代碼:

<ul>
  <li 
    v-for='product in products' 
    :key='product._id' 
    v-if='isLoggedIn' <!-- HERE -->
  >
    {{ product.name }}
  </li>
</ul>


這有什么問題?

和之前一樣。Vue模板會優(yōu)先考慮v-for——所以會遍歷每個元素并檢查v-if

即使最后什么都不渲染,也會循環(huán)數(shù)千個元素。

對于此示例,有一個簡單的解決方案是移動v-if語句。

更好的代碼!

<ul v-if='isLoggedIn'> <!-- Much better -->
  <li 
    v-for='product in products' 
    :key='product._id' 
  >
    {{ product.name }}
  </li>
</ul>


這要好得多,因?yàn)槿绻?code>isLoggedIn為false——那就根本不需要迭代。

6. 訪問循環(huán)中的索引

除了遍歷數(shù)組并訪問每個元素之外,我們還可以跟蹤每個項(xiàng)目的索引。

為此,我們需要在項(xiàng)目之后添加一個索引值。這樣做超級簡單,但對于分頁、顯示列表索引、顯示排名等都很有用。

<ul>
  <li v-for='(products, index) in products' :key='product._id' >
    Product #{{ index }}: {{ product.name }}
  </li>
</ul>


7. 迭代對象

到目前為止,我們只研究了使用v-for來遍歷數(shù)組。但是我們也可以很輕松地學(xué)會迭代對象的鍵值對。

與訪問元素的索引類似,我們需要向循環(huán)中添加另一個值。如果我們使用單個參數(shù)循環(huán)對象,我們將循環(huán)所有項(xiàng)。

如果我們添加另一個參數(shù),則將獲得項(xiàng)和鍵。如果我們添加第三個參數(shù),則還可以訪問v-for循環(huán)的索引。

假設(shè)我們想遍歷產(chǎn)品中的每個屬性。那么代碼如下:

<ul>
  <li v-for='(products, index) in products' :key='product._id' >
    <span v-for='(item, key, index) in product' :key='key'>
      {{ item }}
    </span>
  </li>
</ul>


結(jié)論:
希望這篇文章能幫助你學(xué)到一些關(guān)于使用Vue v-for指令的最佳實(shí)踐。

到此這篇關(guān)于編寫 Vue v-for 循環(huán)的 7 種方式的文章就介紹到這了,更多相關(guān) Vue v-for 循環(huán)的? 方式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue基礎(chǔ)popover彈出框編寫及bug問題分析

    Vue基礎(chǔ)popover彈出框編寫及bug問題分析

    這篇文章主要為大家介紹了Vue基礎(chǔ)popover彈出框編寫及bug問題分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • Vue3+NodeJS+Soket.io實(shí)現(xiàn)實(shí)時聊天的示例代碼

    Vue3+NodeJS+Soket.io實(shí)現(xiàn)實(shí)時聊天的示例代碼

    本文主要介紹了Vue3+NodeJS+Soket.io實(shí)現(xiàn)實(shí)時聊天的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • 在Vue中實(shí)現(xiàn)添加全局store

    在Vue中實(shí)現(xiàn)添加全局store

    這篇文章主要介紹了在Vue中實(shí)現(xiàn)添加全局store方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Vue-input框checkbox強(qiáng)制刷新問題

    Vue-input框checkbox強(qiáng)制刷新問題

    這篇文章主要介紹了Vue-input框checkbox強(qiáng)制刷新問題,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • Vue綁定用戶接口實(shí)現(xiàn)代碼示例

    Vue綁定用戶接口實(shí)現(xiàn)代碼示例

    這篇文章主要介紹了Vue綁定用戶接口代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-11-11
  • vue使用原生js創(chuàng)建元素樣式不生效問題及解決

    vue使用原生js創(chuàng)建元素樣式不生效問題及解決

    這篇文章主要介紹了vue使用原生js創(chuàng)建元素樣式不生效問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • vue自動化路由的實(shí)現(xiàn)代碼

    vue自動化路由的實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue自動化路由的實(shí)現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • 關(guān)于vue-resource報錯450的解決方案

    關(guān)于vue-resource報錯450的解決方案

    本篇文章主要介紹關(guān)于vue-resource報錯450的解決方案,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • Vue用mixin合并重復(fù)代碼的實(shí)現(xiàn)

    Vue用mixin合并重復(fù)代碼的實(shí)現(xiàn)

    這篇文章主要介紹了Vue用mixin合并重復(fù)代碼的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Vue中路由傳參的實(shí)用方式?分享

    Vue中路由傳參的實(shí)用方式?分享

    這篇文章主要為大家詳細(xì)介紹了VUE項(xiàng)目中路由之間的傳值方式,文中的示例代碼講解詳細(xì),涉及到的方法也都是開發(fā)時常用的,希望對大家有多幫助
    2023-06-06

最新評論