Vue.js 条件渲染
v-if
在字符串模板中,比如 Handlebars,我們得像這樣寫一個(gè)條件塊:
| <!-- Handlebars 模板 --> {{#if ok}}<h1>Yes</h1> {{/if}} |
在 Vue 中,我們使用?v-if?指令實(shí)現(xiàn)同樣的功能:
| <h1 v-if="ok">Yes</h1> |
也可以用?v-else?添加一個(gè)“else 塊”:
| <h1 v-if="ok">Yes</h1> <h1 v-else>No</h1> |
在?<template>?元素上使用?v-if?條件渲染分組
因?yàn)?v-if?是一個(gè)指令,所以必須將它添加到一個(gè)元素上。但是如果想切換多個(gè)元素呢?此時(shí)可以把一個(gè)?<template>?元素當(dāng)做不可見的包裹元素,并在上面使用?v-if。最終的渲染結(jié)果將不包含?<template>?元素。
| <template v-if="ok"><h1>Title</h1><p>Paragraph 1</p><p>Paragraph 2</p> </template> |
v-else
你可以使用?v-else?指令來表示?v-if?的“else 塊”:
| <div v-if="Math.random() > 0.5">Now you see me </div> <div v-else>Now you don't </div> |
v-else?元素必須緊跟在帶?v-if?或者?v-else-if?的元素的后面,否則它將不會(huì)被識(shí)別。
v-else-if
2.1.0 新增
v-else-if,顧名思義,充當(dāng)?v-if?的“else-if 塊”,可以連續(xù)使用:
| <div v-if="type === 'A'">A </div> <div v-else-if="type === 'B'">B </div> <div v-else-if="type === 'C'">C </div> <div v-else>Not A/B/C </div> |
類似于?v-else,v-else-if?也必須緊跟在帶?v-if?或者?v-else-if?的元素之后。
用?key?管理可復(fù)用的元素
Vue 會(huì)盡可能高效地渲染元素,通常會(huì)復(fù)用已有元素而不是從頭開始渲染。這么做除了使 Vue 變得非常快之外,還有其它一些好處。例如,如果你允許用戶在不同的登錄方式之間切換:
| <template v-if="loginType === 'username'"><label>Username</label><input placeholder="Enter your username"> </template> <template v-else><label>Email</label><input placeholder="Enter your email address"> </template> |
那么在上面的代碼中切換?loginType?將不會(huì)清除用戶已經(jīng)輸入的內(nèi)容。因?yàn)閮蓚€(gè)模板使用了相同的元素,<input>?不會(huì)被替換掉——僅僅是替換了它的?placeholder。
自己動(dòng)手試一試,在輸入框中輸入一些文本,然后按下切換按鈕:
Username?
Toggle login type
這樣也不總是符合實(shí)際需求,所以 Vue 為你提供了一種方式來表達(dá)“這兩個(gè)元素是完全獨(dú)立的,不要復(fù)用它們”。只需添加一個(gè)具有唯一值的?key?屬性即可:
| <template v-if="loginType === 'username'"><label>Username</label><input placeholder="Enter your username" key="username-input"> </template> <template v-else><label>Email</label><input placeholder="Enter your email address" key="email-input"> </template> |
現(xiàn)在,每次切換時(shí),輸入框都將被重新渲染。請(qǐng)看:
Username?
Toggle login type
注意,<label>?元素仍然會(huì)被高效地復(fù)用,因?yàn)樗鼈儧]有添加?key?屬性。
v-show
另一個(gè)用于根據(jù)條件展示元素的選項(xiàng)是?v-show?指令。用法大致一樣:
| <h1 v-show="ok">Hello!</h1> |
不同的是帶有?v-show?的元素始終會(huì)被渲染并保留在 DOM 中。v-show?只是簡(jiǎn)單地切換元素的 CSS 屬性?display。
注意,v-show?不支持?<template>?元素,也不支持?v-else。
v-if?vs?v-show
v-if?是“真正”的條件渲染,因?yàn)樗鼤?huì)確保在切換過程中條件塊內(nèi)的事件監(jiān)聽器和子組件適當(dāng)?shù)乇讳N毀和重建。
v-if?也是惰性的:如果在初始渲染時(shí)條件為假,則什么也不做——直到條件第一次變?yōu)檎鏁r(shí),才會(huì)開始渲染條件塊。
相比之下,v-show?就簡(jiǎn)單得多——不管初始條件是什么,元素總是會(huì)被渲染,并且只是簡(jiǎn)單地基于 CSS 進(jìn)行切換。
一般來說,v-if?有更高的切換開銷,而?v-show?有更高的初始渲染開銷。因此,如果需要非常頻繁地切換,則使用?v-show?較好;如果在運(yùn)行時(shí)條件很少改變,則使用?v-if?較好。
v-if?與?v-for?一起使用
不推薦同時(shí)使用?v-if?和?v-for。請(qǐng)查閱風(fēng)格指南以獲取更多信息。
當(dāng)?v-if?與?v-for?一起使用時(shí),v-for?具有比?v-if?更高的優(yōu)先級(jí)。請(qǐng)查閱列表渲染指南?以獲取詳細(xì)信息。
from:?https://cn.vuejs.org/v2/guide/conditional.html?
總結(jié)
以上是生活随笔為你收集整理的Vue.js 条件渲染的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Vue.js Class 与 Style
- 下一篇: Vue.js 列表渲染