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)文章
詳解基于Vue-cli搭建的項(xiàng)目如何和后臺(tái)交互
這篇文章主要介紹了詳解基于Vue-cli搭建的項(xiàng)目如何和后臺(tái)交互,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06
elementui時(shí)間/日期選擇器選擇禁用當(dāng)前之前(之后)時(shí)間代碼實(shí)例
當(dāng)我們?cè)谶M(jìn)行網(wǎng)頁(yè)開(kāi)發(fā)時(shí),通常需要用到一些日期組件來(lái)方便用戶(hù)選擇時(shí)間,其中element日期組件是一個(gè)非常好用的工具,這篇文章主要給大家介紹了關(guān)于elementui時(shí)間/日期選擇器選擇禁用當(dāng)前之前(之后)時(shí)間的相關(guān)資料,需要的朋友可以參考下2024-02-02
淺談mint-ui loadmore組件注意的問(wèn)題
下面小編就為大家?guī)?lái)一篇淺談mint-ui loadmore組件注意的問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11
vue 自定義組件 v-model雙向綁定、 父子組件同步通信的多種寫(xiě)法
父子組件通信,都是單項(xiàng)的,很多時(shí)候需要雙向通信。這篇文章主要介紹了vue 自定義組件 v-model雙向綁定、 父子組件同步通信,需要的朋友可以參考下2017-11-11
vue+element實(shí)現(xiàn)下拉菜單并帶本地搜索功能示例詳解
這篇文章主要介紹了vue+element實(shí)現(xiàn)下拉菜單并帶本地搜索功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09
antd vue v-decorator的取值與賦值問(wèn)題
這篇文章主要介紹了antd vue v-decorator的取值與賦值問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04
element滾動(dòng)條組件el-scrollbar的使用詳解
本文主要介紹了element滾動(dòng)條組件el-scrollbar的使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04

