Vue中判斷語句與循環(huán)語句基礎(chǔ)用法及v-if和v-for的注意事項詳解
一、判斷語句
v-if、v-else、v-else-if
v-if是判斷是否將DOM元素顯示出來
不滿足條件的元素,會直接刪除,不會存在瀏覽器上面
v-show
也是用來判斷,是否將DOM元素在頁面上顯示,但是與v-if有著區(qū)別,它的不顯示是通過display:none;實現(xiàn)的,還是存在瀏覽上。
<div id="app"> <h2 v-if="age<18">未成年</h2> <h2 v-else-if="age<60">壯年</h2> <h2 v-else>老年</h2> <h2 v-show="flag">show</h2> <h2 v-if="flag">if</h2> </div> <script src="./vue.js"></script> <script> let vm = new Vue({ el:"#app", data(){ return{ age:71, flag:false//true會顯示,false不會顯示 } } }) </script>
如下圖片顯示,不存在時v-if和v-show的顯示狀態(tài)
可以發(fā)現(xiàn)show是被display:none;影藏起來了
if已經(jīng)從這個世界上消失了
案例
這里用簡單的if判斷,可以通過按鈕控制不同的輸入模式
這里也會出現(xiàn)一個細(xì)節(jié)上的問題,因為Vue會出現(xiàn)大量的復(fù)用情況,所以這里需要在input表單中設(shè)置一個key值,使其出現(xiàn)差別,在以輸入內(nèi)容的表單,切換后內(nèi)容會也會被取消掉。
<div id="app"> <span v-if="usname"> <label for="uname">用戶名</label> <input type="text" id="username" placeholder="輸入用戶名" key="index"> </span> <span v-else="usname"> <label for="email">用戶名郵箱</label> <input type="text" id="email" placeholder="輸入郵箱" key="index1"> </span> <button @click="usname=!usname">選擇</button> </div> <script src="./vue.js"></script> <script> let vm = new Vue({ el:"#app", data(){ return{ usname:true } } }) </script>
二、循環(huán)語句
如下案例
遍歷數(shù)組
是通過循環(huán)來實現(xiàn)點(diǎn)擊變色,這里遍歷出了下標(biāo)和內(nèi)容,在頁面上顯示出來
v-for="(item,index) in list"
item值index索引
<style> .active{ color: red; } </style> </head> <body> <div id="app"> <ul> <li :class="currentIndex==index?'active':''" @click="change(index)" v-for="(item,index) in list">{{index}}--{{item}}</li> </ul> </div> <script src="./vue.js"></script> <script> let vm = new Vue({ el:'#app', data(){ return { currentIndex:0, list:["海王","海賊王","火影忍者","復(fù)仇者聯(lián)盟"], } }, methods:{ change(index){ this.currentIndex=index } } }) </script> </body>
遍歷對象
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> <div id="app"> <!-- 1.遍歷過程沒有使用index索引--> <!-- 格式為:(value, name) --> <ul> <li v-for="(item,key) in user" >{{key+"-"+item}}</li> </ul> <!-- 格式為:(value, name, index) --> <ul> <li v-for="(item,key,index) in user" >{{key+"-"+item+"-"+index}}</li> </ul> </div> <script src="https://cdn.jsdelivr.net/npm/vue@2.6.10/dist/vue.js"></script> <script> const app = new Vue({ el:"#app", data:{ user:{ name:"zzz", height:188, age:24 } } }) </script> </body> </html>
三、v-if和v-for的注意事項
如果將v-if和v-for 在同一個標(biāo)簽內(nèi)使用,會出現(xiàn)每次先循環(huán),在去判斷渲染,在性能上出現(xiàn)了浪費(fèi)
要注意這個細(xì)節(jié),在寫代碼時,可以將for包含到if判斷中,使其不在一個標(biāo)簽內(nèi),從而避免了同是使用的情況。
這里,還會出現(xiàn)一個問題,如果使用index為索引,在渲染表單的時候就會出現(xiàn),表單添加,表單內(nèi)容沒有出現(xiàn)變化,需要自己起一個唯一標(biāo)志符。
附:根據(jù)某一個與待循環(huán)列表無關(guān)的屬性決定是否展示渲染后的數(shù)組對象時,可以把 v-if 上移。
例子:根據(jù) isShow 屬性決定是否顯示 users 列表
users: [ {'name': '111'}, {'name': '222'}, {'name': '333'}, {'name': '444'} ],
isShow: true
改良前:
<ul> <li v-for="user in users" v-if="isShow"> {{ user.name }} </li> </ul>
改良后:
<ul v-if="isShow"> <li v-for="user in users"> {{ user.name }} </li> </ul>
總結(jié)
到此這篇關(guān)于Vue中判斷語句與循環(huán)語句基礎(chǔ)用法及v-if和v-for的注意事項詳解的文章就介紹到這了,更多相關(guān)Vue判斷語句與循環(huán)語句用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue Echarts實現(xiàn)可視化世界地圖代碼實例
這篇文章主要介紹了Vue Echarts實現(xiàn)可視化世界地圖,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05在?Vue?中使用?dhtmlxGantt?組件時遇到的問題匯總(推薦)
dhtmlxGantt一個功能豐富的甘特圖插件,支持任務(wù)編輯,資源分配和多種視圖模式,這篇文章主要介紹了在?Vue?中使用?dhtmlxGantt?組件時遇到的問題匯總,需要的朋友可以參考下2023-03-03