vue中v-for指令完成列表渲染
本文就Vue中列表渲染做個(gè)簡(jiǎn)單總結(jié)和使用演示:
列表渲染是用v-for指令根據(jù)綁定一組元素的選項(xiàng)來(lái)完成的,渲染格式可以自定義。
1、列表遍歷
最基本的使用案例1:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>列表渲染</title>
<script src="../../js/vue.js"></script>
</head>
<body>
<div id="app">
<ul>
<li v-for="(name,index) in names">
{{index}}-{{name}}
</li>
</ul>
</div>
</body>
<script>
new Vue({
el:'#app',
data() {
return {
names:['張三','李四','王五','趙六']
}
},
})
</script>
</html>
上面的例子中:通過(guò)v-for指令,綁定data中的names數(shù)組,以列表的形式遍歷出數(shù)組中的元素,其中name代表當(dāng)前數(shù)組的一個(gè)遍歷元素,index是當(dāng)前元素name在數(shù)組中的索引,輸出效果如下:

v-for還可以遍歷對(duì)象,字符串,指定數(shù)字等等。如:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>列表渲染</title>
<script src="../../js/vue.js"></script>
</head>
<body>
<div id="app">
<!-- 遍歷對(duì)象 -->
<ul>
<li v-for="(propery,key) in student">
{{key}}:{{propery}}
</li>
</ul>
<!-- 遍歷字符串 -->
<ol>
<li v-for="char in str">{{char}}</li>
</ol>
<!-- 自定義輸出 -->
<ul>
<li v-for="num in 10">
{{num}}
</li>
</ul>
</div>
</body>
<script>
new Vue({
el:'#app',
data() {
return {
student:{
name:'李明',
age:23,
address:'大連'
},
str:'HelloWord'
}
},
})
</script>
</html>
上面代碼的效果如下:

2、Vue中key的作用
作用:
key是虛擬dom對(duì)象的標(biāo)識(shí),當(dāng)數(shù)據(jù)發(fā)生變化時(shí),vue會(huì)根據(jù)【新數(shù)據(jù)】生成【新的虛擬dom】,隨后Vue進(jìn)行【新虛擬dom】和【舊虛擬dom】的差異對(duì)比
差異對(duì)比規(guī)則:
- 先是在【舊虛擬dom】中找到與【新虛擬dom】相同的
key - (1)若虛擬
dom中的內(nèi)容沒(méi)變,直接使用之前的真實(shí)dom - (2)若虛擬
dom中的內(nèi)容邊了,則生成新的真實(shí)dom,隨后替換掉頁(yè)面中之前的真實(shí)dom - 若在【舊虛擬dom】中沒(méi)有找到和【新虛擬dom】相同的key,就創(chuàng)建新的真實(shí)dom,隨后渲染到頁(yè)面中
3、列表過(guò)濾
列表過(guò)濾即在進(jìn)行列表遍歷前對(duì)列表元素進(jìn)行一次篩選,選擇出符合要求元素進(jìn)行展示,如:
假如我們要過(guò)濾掉列表里名為‘張三'的人:(可以用computer或者watch這兩個(gè)屬性實(shí)現(xiàn))
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>列表渲染</title>
<script src="../../js/vue.js"></script>
</head>
<body>
<div id="app">
<!-- 列表過(guò)濾 -->
<!-- computer方式 -->
<ul>
<li v-for="(name,intdex) in showNames">{{name}}</li>
</ul>
<!-- watch方式 -->
<ol>
<li v-for="(name,index) in displayName">{{name}}</li>
</ol>
</div>
</body>
<script>
new Vue({
el:'#app',
data() {
return {
names:['張三','李四','王五','趙六'],
displayName:[],
}
},
watch: {
name:{
immediate:true,
handler(val){
this.displayName=this.names.filter((n)=>{
return n!='張三'
})
}
}
},
computed: {
// 假如我們要過(guò)濾掉名為'張三'的人
showNames(){
return this.names.filter((n)=>{
return n!="張三"
})
}
},
})
</script>
</html>
效果:

到此這篇關(guān)于 vue中v-for指令完成列表渲染的文章就介紹到這了,更多相關(guān) vue中v-for指令內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
前端本地存儲(chǔ)方案localForage在vue3中使用方法
localForage是前端本地存儲(chǔ)的庫(kù),支持多種存儲(chǔ)后端,并提供了一致的API來(lái)存儲(chǔ)和檢索數(shù)據(jù),這篇文章主要給大家介紹了關(guān)于前端本地存儲(chǔ)方案localForage在vue3中使用的相關(guān)資料,需要的朋友可以參考下2024-09-09
Vue實(shí)現(xiàn)英文字母大小寫(xiě)在線轉(zhuǎn)換功能
在Web開(kāi)發(fā)中,字符串處理是常見(jiàn)的需求之一,特別是在國(guó)際化應(yīng)用中,對(duì)于文本的格式化處理尤為重要,本文將介紹如何使用Vue.js來(lái)構(gòu)建一個(gè)簡(jiǎn)單的在線英文字母大小寫(xiě)轉(zhuǎn)換工具,需要的朋友可以參考下2024-09-09
vue跳轉(zhuǎn)頁(yè)面常用的4種方法與區(qū)別小結(jié)
這篇文章主要給大家介紹了關(guān)于vue跳轉(zhuǎn)頁(yè)面常用的4種方法與區(qū)別,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-03-03
vue動(dòng)態(tài)組件實(shí)現(xiàn)選項(xiàng)卡切換效果
這篇文章主要為大家詳細(xì)介紹了vue動(dòng)態(tài)組件實(shí)現(xiàn)選項(xiàng)卡切換效果的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
vue打包并部署到nginx上的實(shí)現(xiàn)示例
本文主要介紹了vue打包并部署到nginx上的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-01-01
vue計(jì)算屬性時(shí)v-for處理數(shù)組時(shí)遇到的一個(gè)bug問(wèn)題
這篇文章主要介紹了在做vue計(jì)算屬性,v-for處理數(shù)組時(shí)遇到的一個(gè)bug 問(wèn)題,需要的朋友可以參考下2018-01-01
Vue.js中使用Vuex實(shí)現(xiàn)組件數(shù)據(jù)共享案例
這篇文章主要介紹了Vue.js中使用Vuex實(shí)現(xiàn)組件數(shù)據(jù)共享案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07
解決$store.getters調(diào)用不執(zhí)行的問(wèn)題
今天小編就為大家分享一篇解決$store.getters調(diào)用不執(zhí)行的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11

