2024-09-15|閱讀時間 ‧ 約 22 分鐘

EP7 - 條件渲染

Conditional Rendering 這是什麼?
符合條件就渲染嗎?怎麼感覺v-bind也可以達到條件渲染
應該還是有點區別吧~先來看看吧

v-if

指令 v-if 用於有條件地渲染區塊。只有當指令表達式返回真值,該區塊才會被渲染。

<template>
<h1 v-if="awesome">Vue is awesome!</h1>
</template>

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>
</template>

Try it in the playground

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>
</template>

v-else 類似,v-else-if 元素必須緊跟在 v-ifv-else-if 元素之後。

v-if 用於 <template>

因為 v-if 是一個指令,所以它必須附加到單個元素上。但是,如果我們想切換多個元素呢?在這種情況下,我們可以在 <template> 元素上使用 v-if,它充當一個隱形的包裝器。最終渲染的結果將不包括 <template> 元素。

<template v-if="ok">
<h1>Title</h1>
<p>Paragraph 1</p>
<p>Paragraph 2</p>
</template>

v-show

另一種條件顯示元素的選擇是 v-show 指令。用法基本相同:

<h1 v-show="ok">Hello!</h1>

不同的是,使用 v-show 的元素將始終被渲染並保持在 DOM 中;v-show 只會切換元素的 display CSS 屬性。

v-show 不支持 <template> 元素,也不能與 v-else 一起使用。

v-if vs. v-show

  • v-if 是“真實”的條件渲染,因為它確保在切換時,條件塊內的事件監聽器和子組件會被正確地銷毀和重新創建。
    v-if 也是懶的:如果初始渲染時條件為假,則不會執行任何操作,直到條件第一次變為真時,條件區塊才會被渲染。
  • v-show 相對簡單 — 元素無論初始條件如何,總是會被渲染,只是基於 CSS 的切換。

v-if 與 v-for

注意:不建議在同一元素上使用 v-ifv-for,因為它們之間存在隱式的優先順序。請參閱風格指南以獲取詳細信息。

v-ifv-for 同時用於同一元素時,v-if 會首先被評估。請參見列表渲染指南以獲取詳細信息。

Q: 等等!!! 什麼是v-for?

內容跳來跳去介紹各種元素,沒有人能有空讀完全部官方文件~
只好先查一下了~

v-for 是 Vue.js 中用來進行列表渲染的指令。它可以讓你根據一個陣列或物件中的數據動態生成一組元素。

v-for 的基本語法是:

<div v-for="item in items" :key="item.id">
{{ item.name }}
</div>

這裡 items 是一個陣列,item 是陣列中的每一個元素。v-for 會為 items 中每個元素生成一個 <div> 元素,並將 item.name 的值顯示在每個 <div> 元素中。

1. 循環陣列

<ul>
<li v-for="item in items" :key="item.id">{{ item.name }}</li>
</ul>
data() {
return {
items: [
{ id: 1, name: 'Apple' },
{ id: 2, name: 'Banana' },
{ id: 3, name: 'Cherry' }
]
}
}

2. 循環物件

<ul>
<li v-for="(value, key) in object" :key="key">{{ key }}: {{ value }}</li>
</ul>
data() {
return {
object: {
name: 'Vue',
type: 'Framework',
version: '3.x'
}
}
}

3. 循環數字範圍

<ul>
<li v-for="n in 10" :key="n">{{ n }}</li>
</ul>

這會渲染從 1 到 10 的數字列表。

使用 :key 屬性可以幫助 Vue 在更新虛擬 DOM 時更高效地跟蹤每一個項目。key 應該是唯一的,以便 Vue 能夠正確識別每個元素的變化。

Q: 有沒有辦法在vocus上展現vue組件?

無法,只好點擊連結去playground才能測試。
原本是想寫文章在Github Pages上架的網站,那邊應該可以放上組件~
但還是vocus的SEO做得比較好啊~先養成技術文章撰寫好了www~

Q: 為什麼文件會寫template tag?有時候卻沒有?

在 Vue 的文件中,有時候會看到 template 標籤,有時候則沒有,這取決於示例代碼的上下文和具體展示的內容。以下是幾種常見情況的解釋:

1. 完整的 Vue 組件示例

當展示一個完整的 Vue 組件時,通常會包括 template 標籤,script 標籤,甚至 style 標籤,這樣可以展示組件的結構和各部分的相互關係

<template>
<div>
<h1 v-if="awesome">Vue is awesome!</h1>
<h1 v-else>Oh no 😢</h1>
</div>
</template>

<script>
export default {
data() {
return {
awesome: true
}
}
}
</script>

<style>
/* 組件的樣式 */
</style>

2. 局部代碼片段

當文件中僅僅展示某個特定功能或特性的代碼片段時,通常只包含必要的代碼,省略了 template 標籤,以便讀者能夠專注於當前展示的特性。

例如,只展示 v-if 指令的用法:

<h1 v-if="awesome">Vue is awesome!</h1>

或者展示計算屬性的定義:

const computedValue = computed(() => {
return someReactiveValue * 2;
});

3. 專注於某個部分的示例

在一些情況下,文件只需要展示 template 部分,或者只需要展示 script 部分,這樣可以更清晰地表達當前的重點內容。

例如,展示如何使用 v-ifv-else

<template>
<button @click="awesome = !awesome">Toggle</button>

<h1 v-if="awesome">Vue is awesome!</h1>
<h1 v-else>Oh no 😢</h1>
</template>

或者展示如何定義一個響應式數據:

<script>
export default {
data() {
return {
awesome: true
}
}
}
</script>

Q: 差異 v-if, v-bind:style, v-bind:class

使用 v-if

v-if 會根據條件動態地創建或銷毀 DOM 元素:

<template>
<div v-if="isVisible">這個元素根據 isVisible 來顯示或隱藏</div>
</template>

<script setup>
import { ref } from 'vue'

const isVisible = ref(true)
</script>

使用 v-bind:style

可以通過 v-bind:style 動態綁定 display 屬性來實現顯示或隱藏效果:

<template>
<div :style="{ display: isVisible ? 'block' : 'none' }">這個元素根據 isVisible 來顯示或隱藏</div>
</template>

<script setup>
import { ref } from 'vue'

const isVisible = ref(true)
</script>

使用 v-bind:class

可以通過 v-bind:class 動態添加或移除 CSS 類來實現顯示或隱藏效果:

<template>
<div :class="{ hidden: !isVisible }">這個元素根據 isVisible 來顯示或隱藏</div>
</template>

<style>
.hidden {
display: none;
}
</style>

<script setup>
import { ref } from 'vue'

const isVisible = ref(true)
</script>

比較

  1. v-if
    • 優點:當條件為假時,元素及其子元素不會被創建,節省了 DOM 的開銷。
    • 缺點:每次條件變化時,元素會被重新創建或銷毀,性能開銷較大。
  2. v-bind:style
    • 優點:僅通過更新 display 樣式屬性來顯示或隱藏元素,不會銷毀元素,性能較好。
    • 缺點:元素仍然存在於 DOM 中,只是不可見。
  3. v-bind:class
    • 優點:通過添加或移除 CSS 類來顯示或隱藏元素,靈活且性能較好。
    • 缺點:需要額外定義 CSS 類來實現隱藏效果。
慢慢對於這個框架有了基礎的概念~
好像真的很方便耶,但怎麼還有這麼多內容要看啊www
假如比較複雜的邏輯要怎麼實現?然後很期待可重復性能有多高?
分享至
成為作者繼續創作的動力吧!
© 2024 vocus All rights reserved.