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

Vue指令之v-for的使用說明

 更新時間:2022年04月08日 11:22:53   作者:北海之靈  
這篇文章主要介紹了Vue指令之v-for的使用說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Vue v-for的使用

1.迭代普通數(shù)組

在data中定義普通數(shù)組

data:{
? ? ? list:[1,2,3,4,5,6]
}

在html中使用 v-for 指令渲染

<p v-for="(item,i) in list">--索引值--{{i}} ? --每一項--{{item}}</p>

2.迭代對象數(shù)組

在data中定義對象數(shù)組

data:{
? ? ? list:[1,2,3,4,5,6],
? ? ? listObj:[
? ? ? ? {id:1, name:'zs1'},
? ? ? ? {id:2, name:'zs2'},
? ? ? ? {id:3, name:'zs3'},
? ? ? ? {id:4, name:'zs4'},
? ? ? ? {id:5, name:'zs5'},
? ? ? ? {id:6, name:'zs6'},
? ? ? ]
}

在html中使用 v-for 指令渲染

<p v-for="(user,i) in listObj">--id--{{user.id}} ? --姓名--{{user.name}}</p>

3.迭代對象

在data中定義對象

data:{
? ? ? user:{
? ? ? ? id:1,
? ? ? ? name:'托尼.賈',
? ? ? ? gender:'男'
? ? ? }
}

在html中使用 v-for 指令渲染

<p v-for="(val,key) in user">--鍵是--{{key}}--值是--{{val}}</p>

4.迭代數(shù)字

<!-- 注意:如果使用v-for迭代數(shù)字的話,前面 count 的值從 1 開始-->
<p v-for="count in 10">這是第{{count}}次循環(huán)</p>

完整代碼:

<html>
? <head>
? ? <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
? </head>
<body>
? <div id='app'>
? ? <!--v-for循環(huán)普通數(shù)組-->
? ? <p v-for="(item,i) in list">--索引值--{{i}} ? --每一項--{{item}}</p>
? ? <br/>
? ? <!--v-for循環(huán)對象數(shù)組-->
? ? <p v-for="(user,i) in listObj">--id--{{user.id}} ? --姓名--{{user.name}}</p>
? ? <br/>
? ? <!--注意,在遍歷對象的鍵值對的時候,除了有 val 和 key,在第三個位置還有一個索引-->
? ? <p v-for="(val,key) in user">--鍵是--{{key}} ?--值是--{{val}}</p>
? ? <br/>
? ? <!-- in 后面我們放過數(shù)組、對象數(shù)組、對象,還可以放數(shù)字-->
? ? <!-- 注意:如果使用v-for迭代數(shù)字的話,前面 count 的值從 1 開始-->
? ? <p v-for="count in 10">這是第{{count}}次循環(huán)</p>
? </div>
</body>
<script src="vue.min.js"></script>
<script>
? var vm = new Vue({
? ? el:'#app',
? ? data:{
? ? ? list:[1,2,3,4,5,6],
? ? ? listObj:[
? ? ? ? {id:1, name:'zs1'},
? ? ? ? {id:2, name:'zs2'},
? ? ? ? {id:3, name:'zs3'},
? ? ? ? {id:4, name:'zs4'},
? ? ? ? {id:5, name:'zs5'},
? ? ? ? {id:6, name:'zs6'},
? ? ? ],
? ? ? user:{
? ? ? ? id:1,
? ? ? ? name:'托尼.賈',
? ? ? ? gender:'男'
? ? ? }
? ? }
? });
</script>
</html>

截圖:

v-for的最佳使用技巧

在vuejs中,v-for 的使用是比較常見的,它允許您在模板代碼中編寫for循環(huán)。那么在使用v-for的時候,可曾思考過使用這個指令的一些技巧嗎?

在介紹它的使用技巧之前,我先介紹下它的基本用法吧,在vue中v-for可以遍歷數(shù)組、對象、字符串,但是用的最多的還是遍歷數(shù)組,基本方法如下:

<div id="app">
?? ?<ul>
? <li v-for='item in list'>
? ? {{ item.name }}
? </li>
</ul>
</div>

可能有些初學者在使用的過程中,不會考慮太多的使用技巧,直接遍歷定義在data中的數(shù)據(jù),其實vue在設計的初衷,也考慮到了這個問題,如果頻繁使用data中的數(shù)據(jù),可能會造成一些性能上的消耗,是相當不友好的。

在本篇文章中,我將介紹六種方法來使你的 v-for 代碼更加精確,可預測和強大。

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

建議在遍歷數(shù)據(jù)的時候,都盡可能的加上key,設置一個惟一的鍵屬性,它可以確保組件以您期望的方式工作。有些時候,可能使用索引index也可以,但是在一些特定的場景下,比如多場景登錄下,如果不使用key來標識當前使用的登錄方式,那么可能會造成數(shù)據(jù)的紊亂問題,如果數(shù)據(jù)量比較大, 頁面的數(shù)據(jù)更新時會造成渲染數(shù)據(jù)消耗很大的性能甚至出現(xiàn)不可預測的bug,如果我們對每個元素都有唯一的鍵引用,那么我們就可以更好地準確地預測DOM將如何操作,就可以避免很多不必要的問題出現(xiàn)。

<div id="app">
?? ?<ul>
? <li v-for='item in list' ?:key='item.id'>
? ? {{ item.name }}
? </li>
</ul>
</div>

2.不要在循環(huán)中使用v-if

一個超級常見的錯誤是使用 v-if 來過濾 v-for 循環(huán)的數(shù)據(jù)。Vuejs優(yōu)先考慮 v-for 而不是 v-if,這意味著組件將循環(huán)遍歷每個元素,然后檢查 v-if 條件以確定是否應渲染。因此,實際上,無論條件是什么,都將遍歷數(shù)組。盡管這看起來很直觀,但它會導致一個巨大的性能問題

/*千萬不要這樣寫,切記切記*/
<div id="app">
?? ?<ul>
? <li v-for='item in list'
? ? ? :key='item.id'
? ? ? v-if="item.price<50"
? ? ? >
? ? {{ item.name }}
? </li>
</ul>
</div>

3.使用計算屬性或方法來處理數(shù)據(jù)后再做數(shù)據(jù)遍歷

為避免上述問題,我們應該在遍歷模板中的數(shù)據(jù)之前對其進行過濾。有兩種非常相似的方法

  • 使用計算屬性
  • 使用過濾方法

首先,我們只需要設置一個計算屬性,為了獲得與之前的v-if相同的功能,代碼應如下所示。

<div id="app">
?? ?<ul>
? <li v-for='item in underPrice'
? ? ? :key='item.id'
? ? ? >
? ? {{ item.name }}
? </li>
</ul>
</div>
<script>
? export default {
? ? data () {
? ? ? return {
? ? ? ? list: []
? ? ? }
? ? },
? ? computed: {
? ? ? underPrice: function () {
? ? ? ? return this.list.filter(item=> item.price < 50)
? ? ? }
? ? }
? }
</script>

計算屬性是作為屬性使用的,并不是方法。使用computed,可以將數(shù)據(jù)做緩存處理,在每次渲染數(shù)據(jù)的時候,會優(yōu)先在緩存在找該數(shù)據(jù),如果有了直接從緩存中取出渲染,如果沒有的話再重新獲取。這樣也大大的提高了性能。

或者可以使用方式來進行變量的篩選以及處理再做遍歷

<div id="app">
?? ?<ul>
? <li v-for='item in underPriceHandle(50)'
? ? ? :key='item.id'
? ? ? >
? ? {{ item.name }}
? </li>
</ul>
</div>
<script>
? export default {
? ? data () {
? ? ? return {
? ? ? ? list: []
? ? ? }
? ? },
? ? methods: {
? ? ? underPriceHandle: function (price) {
? ? ? ? return this.list.filter(item=> item.price < price)
? ? ? }
? ? }
? }
</script>

4.在一個范圍內(nèi)循環(huán)

盡管大多數(shù)情況下,v-for 用于遍歷數(shù)組或?qū)ο?,但在某些情況下,我們肯定只希望循環(huán)執(zhí)行一定次數(shù)。

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

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

5.在循環(huán)中訪問項目的索引

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

為此,我們必須在項目后添加一個索引值,它非常簡單,可用于分頁,顯示列表索引,顯示排名等。

<ul>
? <li v-for='(item, index) in products' :key='item.id' >
? ?{{ index }}----{{ item.name }}
? </li>
</ul>

6.遍歷一個對象

我們也可以使用v-for輕松地遍歷對象的鍵值對。

與訪問元素的索引類似,我們必須向循環(huán)中添加另一個值。如果我們用一個參數(shù)遍歷一個對象,我們將遍歷所有的項。

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

<ul>
? <li v-for='(list, index) in lists' :key='list.id' >
? ? <span v-for='(item, key, index) in list' :key='key'>
? ? ? {{ item }}
? ? </span>
? </li>
</ul>

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。 

相關文章

  • vue組件通信傳值操作示例

    vue組件通信傳值操作示例

    這篇文章主要介紹了vue組件通信傳值操作,結(jié)合實例形式分析了vue.js父子組件通信及兄弟組件通信相關操作技巧,需要的朋友可以參考下
    2019-01-01
  • Element-UI?el-table對循環(huán)產(chǎn)生的空白列賦默認值方式

    Element-UI?el-table對循環(huán)產(chǎn)生的空白列賦默認值方式

    這篇文章主要介紹了Element-UI?el-table對循環(huán)產(chǎn)生的空白列賦默認值方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue組件傳值(高級)、屬性傳值、反向傳值、跨級傳值實例詳解

    vue組件傳值(高級)、屬性傳值、反向傳值、跨級傳值實例詳解

    父組件通過屬性傳值給子組件,父組件修改數(shù)據(jù)后會刷新頁面并重新傳值給子組件,子組件可以修改父組件傳的值并刷新自己的頁面?但是并不會修改父組件中的值,這篇文章主要介紹了vue組件傳值(高級)、屬性傳值、反向傳值、跨級傳值,需要的朋友可以參考下
    2022-09-09
  • 淺談Vue內(nèi)置component組件的應用場景

    淺談Vue內(nèi)置component組件的應用場景

    這篇文章主要介紹了淺談Vue內(nèi)置component組件的應用場景,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • Vue路由跳轉(zhuǎn)方式區(qū)別匯總(push,replace,go)

    Vue路由跳轉(zhuǎn)方式區(qū)別匯總(push,replace,go)

    vue項目中點擊router-link標簽鏈接都屬于聲明式導航。vue項目中編程式導航有this.$router.push(),this.$router.replace(),this.$router.go()???????。這篇文章主要介紹了Vue路由跳轉(zhuǎn)方式區(qū)別匯總(push,replace,go)
    2022-12-12
  • vuex中mapActions的概念及基本用法

    vuex中mapActions的概念及基本用法

    mapActions 就是將組件中的函數(shù)映射為對應的action,通過本文我們了解了mapActions 大概是用來干什么的,接下來介紹一下 mapActions 的具體用法,感興趣的朋友一起看看吧
    2023-09-09
  • 一篇文章帶你了解Vue組件的創(chuàng)建和使用

    一篇文章帶你了解Vue組件的創(chuàng)建和使用

    這篇文章主要為大家介紹了Vue組件的創(chuàng)建和使用,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • Vue前端登錄token信息驗證功能實現(xiàn)

    Vue前端登錄token信息驗證功能實現(xiàn)

    最近公司新啟動了個項目,用的是vue框架在做,下面這篇文章主要給大家介紹了關于vue實現(xiàn)token登錄驗證的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-12-12
  • vue-cli創(chuàng)建項目及項目結(jié)構(gòu)解析

    vue-cli創(chuàng)建項目及項目結(jié)構(gòu)解析

    上一篇我們安裝了vue-cli,接下來我們就使用該腳手架進行創(chuàng)建項目,這篇文章主要介紹了vue-cli創(chuàng)建項目以及項目結(jié)構(gòu)的相關資料,需要的朋友可以參考下面文章的具體內(nèi)容
    2021-10-10
  • 深入探索Vue3.x中的七大高級用法

    深入探索Vue3.x中的七大高級用法

    Vue3.x 自發(fā)布以來,憑借其性能的顯著提升和更加靈活的組合式 API,已經(jīng)成為了現(xiàn)代前端開發(fā)的重要工具之一,除了基本用法外,Vue3.x 還提供了許多高級功能,本文將和大家一起深入探索Vue3.x中的七大高級用法,需要的朋友可以參考下
    2024-03-03

最新評論