條件渲染
v-if
指令v-if
用於條件性地渲染一個塊。只有當指令的表示式返回一個真值時,該塊才會被渲染。
template
<h1 v-if="awesome">Vue is awesome!</h1>
v-else
您可以使用v-else
指令來指示v-if
的“else塊”
template
<button @click="awesome = !awesome">Toggle</button>
<h1 v-if="awesome">Vue is awesome!</h1>
<h1 v-else>Oh no 😢</h1>
Vue很棒!
v-else
元素必須立即跟在v-if
或v-else-if
元素之後——否則它將不會被識別。
v-else-if
正如其名所示,v-else-if
充當了v-if
的“else if塊”。它也可以多次鏈式使用
template
<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
元素之後。
v-if
在
因為v-if
是一個指令,它必須附加到一個單一元素上。但如果我們想切換多個元素呢?在這種情況下,我們可以在元素上使用v-if
,它充當一個不可見的包裝器。最終的渲染結果將不包括元素。
template
<template v-if="ok">
<h1>Title</h1>
<p>Paragraph 1</p>
<p>Paragraph 2</p>
</template>
v-else
和v-else-if
也可以用於。
v-show
另一種條件性地顯示元素的選項是v-show
指令。其用法在很大程度上是相同的
template
<h1 v-show="ok">Hello!</h1>
不同之處在於,具有v-show
的元素總是會渲染並保留在DOM中;v-show
僅切換元素的display
CSS屬性。
v-show
不支援<template>
元素,也不與v-else
一起使用。
v-if
與v-show
v-if
是“真實”的條件渲染,因為它確保在切換期間,條件塊內的監聽器和子元件被正確銷燬和重新建立。
v-if
也是懶載入的:如果初始渲染時條件為假,它將不執行任何操作——條件塊不會渲染,直到條件第一次變為真。
相比之下,v-show
要簡單得多——元素總是渲染,不管初始條件如何,透過CSS切換。
一般來說,v-if
具有更高的切換成本,而 v-show
具有更高的初始渲染成本。因此,如果您需要經常切換某個元素,建議使用 v-show
;如果條件在執行時不太可能改變,則建議使用 v-if
。
v-if
與 v-for
注意
由於存在隱含優先順序,不建議在同一元素上同時使用 v-if
和 v-for
。有關詳細資訊,請參閱 風格指南。
當同一元素上同時使用 v-if
和 v-for
時,v-if
將首先被評估。有關詳細資訊,請參閱 列表渲染指南。