目錄
另一個用來根據條件顯示元素的選項是
首頁 web前端 js教程 Vue.js條件渲染詳解

Vue.js條件渲染詳解

Mar 31, 2018 pm 05:00 PM
javascript vue.js 詳解


本文主要和大家分享Vue.js條件渲染詳解,在字串模板中,例如Handlebars,我們得像這樣寫一個條件塊:

<!-- Handlebars 模板 -->{{#if ok}}
    <h1>Yes</h1>{{/if}}
登入後複製
登入後複製

在Vue 中,我們使用v-if 指令實作相同的功能:

<h1 v-if="ok">Yes</h1>
登入後複製
登入後複製

也可以用v-else 新增一個「else 區塊」:

<h1 v-if="ok">Yes</h1>

No

登入後複製
登入後複製

# 在<template> 元素上使用v-if 條件渲染分組

##因為

v-if 是一個指令,所以必須將它加到一個元素上。但是如果想切換多個元素呢?此時可以把一個 <template> 元素當做不可見的包裹元素,並在上面使用 v-if。最終的渲染結果將不包含 <template> 元素。 <div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>&lt;p id=&quot;example&quot;&gt; &lt;template v-if=&amp;#39;ok&amp;#39;&gt; &lt;h1&gt;Title&lt;/h1&gt; &lt;p&gt;Paragraph 1&lt;/p&gt; &lt;p&gt;Paragraph 2&lt;/p&gt; &lt;/template&gt;&lt;/p&gt;</pre><div class="contentsignin">登入後複製</div></div><div class="contentsignin">登入後複製</div></div><div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>var vm = new Vue({ el: &amp;#39;#example&amp;#39;, data: { ok: true } })</pre><div class="contentsignin">登入後複製</div></div><div class="contentsignin">登入後複製</div></div>

#v-elsev-else-if

可以使用

v-else 指令來表示v-if 的「else 區塊」:<div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>&lt;p v-if=&quot;Math.random() &gt; 0.5&quot;&gt; Now you see me&lt;/p&gt; &lt;p v-else&gt; Now you don&amp;#39;t &lt;/p&gt;</pre><div class="contentsignin">登入後複製</div></div><div class="contentsignin">登入後複製</div></div><div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>&lt;p v-if=&quot;type === &amp;#39;A&amp;#39;&quot;&gt; A &lt;/p&gt; &lt;p v-else-if=&quot;type === &amp;#39;B&amp;#39;&quot;&gt; B &lt;/p&gt; &lt;p v-else-if=&quot;type === &amp;#39;C&amp;#39;&quot;&gt; C &lt;/p&gt; &lt;p v-else&gt; Not A/B/C &lt;/p&gt;</pre><div class="contentsignin">登入後複製</div></div><div class="contentsignin">登入後複製</div></div>

v-else 元素必須緊跟著帶v-ifv-else-if 的元素的後面,否則它將不會被識別。

類似於

v-elsev-else-if 也必須緊接在帶v-ifv- else-if 的元素之後。

v-show

另一個用來根據條件顯示元素的選項是

v-show 指令。

<h1 v-show="ok">Hello!</h1>
登入後複製
登入後複製

不同的是帶有

v-show 的元素總是會被渲染並保留在 DOM 中。 v-show 只是簡單地切換元素的 CSS 屬性 display。

注意,v-show 不支援 <template> 元素,也不支援 v-else

v-if vs v-show

v-if 是「真正」的條件渲染,因為它會確保在切換過程中條件區塊內的事件監聽器和子元件適當地被銷毀和重建。

v-if 也是惰性的:如果在初始渲染時條件為假,則什麼也不做-直到條件第一次變成真時,才會開始渲染條件塊。

相較之下,

v-show 就簡單得多——不管初始條件是什麼,元素總是會被渲染,並且只是簡單地基於 CSS 進行切換。

一般來說,

v-if 有更高的切換開銷,而 v-show 有更高的初始渲染開銷。因此,如果需要非常頻繁地切換,則使用 v-show 較好;如果在運行時條件很少改變,則使用 v-if 較好。

v-if

在字串模板中,例如Handlebars,我們得像這樣寫一個條件區塊:

<!-- Handlebars 模板 -->{{#if ok}}
    <h1>Yes</h1>{{/if}}
登入後複製
登入後複製

在Vue 中,我們使用

v -if 指令實作同樣的功能:

<h1 v-if="ok">Yes</h1>
登入後複製
登入後複製

也可以用

v-else 新增一個「else 區塊」:

<h1 v-if="ok">Yes</h1>

No

登入後複製
登入後複製

# 在<template> 元素上使用v-if 條件渲染分組##因為

v-if

是指令,所以必須將它添加到一個元素上。但是如果想切換多個元素呢?此時可以把一個 <template> 元素當做不可見的包裹元素,並在上面使用 v-if。最終的渲染結果將不包含 <template> 元素。 <div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>&lt;p id=&quot;example&quot;&gt; &lt;template v-if=&amp;#39;ok&amp;#39;&gt; &lt;h1&gt;Title&lt;/h1&gt; &lt;p&gt;Paragraph 1&lt;/p&gt; &lt;p&gt;Paragraph 2&lt;/p&gt; &lt;/template&gt;&lt;/p&gt;</pre><div class="contentsignin">登入後複製</div></div><div class="contentsignin">登入後複製</div></div><div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>var vm = new Vue({ el: &amp;#39;#example&amp;#39;, data: { ok: true } })</pre><div class="contentsignin">登入後複製</div></div><div class="contentsignin">登入後複製</div></div>

#v-elsev-else-if可以使用

v-else

指令來表示v-if 的「else 區塊」:<div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>&lt;p v-if=&quot;Math.random() &gt; 0.5&quot;&gt; Now you see me&lt;/p&gt; &lt;p v-else&gt; Now you don&amp;#39;t &lt;/p&gt;</pre><div class="contentsignin">登入後複製</div></div><div class="contentsignin">登入後複製</div></div><div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>&lt;p v-if=&quot;type === &amp;#39;A&amp;#39;&quot;&gt; A &lt;/p&gt; &lt;p v-else-if=&quot;type === &amp;#39;B&amp;#39;&quot;&gt; B &lt;/p&gt; &lt;p v-else-if=&quot;type === &amp;#39;C&amp;#39;&quot;&gt; C &lt;/p&gt; &lt;p v-else&gt; Not A/B/C &lt;/p&gt;</pre><div class="contentsignin">登入後複製</div></div><div class="contentsignin">登入後複製</div></div>

v-else

元素必須緊跟著帶v-ifv-else-if 的元素的後面,否則它將不會被識別。 類似於

v-else

v-else-if 也必須緊接在帶v-ifv- else-if 的元素之後。 v-show

另一個用來根據條件顯示元素的選項是

v-show

指令。 <div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>&lt;h1 v-show=&quot;ok&quot;&gt;Hello!&lt;/h1&gt;</pre><div class="contentsignin">登入後複製</div></div><div class="contentsignin">登入後複製</div></div>不同的是帶有 v-show<p> 的元素總是會被渲染並保留在 DOM 中。 <code>v-show 只是簡單地切換元素的 CSS 屬性 display。

注意,

v-show 不支援 <template> 元素,也不支援 v-elsev-if vs v-show

v-if

是「真正」的條件渲染,因為它會確保在切換過程中條件區塊內的事件監聽器和子元件適當地被銷毀和重建。

v-if

也是惰性的:如果在初始渲染時條件為假,則什麼也不做-直到條件第一次變成真時,才會開始渲染條件塊。 相較之下,

v-show

就簡單得多——不管初始條件是什麼,元素總是會被渲染,並且只是簡單地基於 CSS 進行切換。 <p>一般來說,<code>v-if 有更高的切換開銷,而 v-show 有更高的初始渲染開銷。因此,如果需要非常頻繁地切換,則使用 v-show 較好;如果在運行時條件很少改變,則使用 v-if 較好。

相關推薦:

Vue.js—條件渲染

#

以上是Vue.js條件渲染詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Win11管理員權限取得詳解 Win11管理員權限取得詳解 Mar 08, 2024 pm 03:06 PM

Windows作業系統是全球最受歡迎的作業系統之一,其新版本Win11備受矚目。在Win11系統中,管理員權限的取得是一個重要的操作,管理員權限可以讓使用者對系統進行更多的操作和設定。本文將詳細介紹在Win11系統中如何取得管理員權限,以及如何有效地管理權限。在Win11系統中,管理員權限分為本機管理員和網域管理員兩種。本機管理員是指具有對本機電腦的完全管理權限

Oracle SQL中的除法運算詳解 Oracle SQL中的除法運算詳解 Mar 10, 2024 am 09:51 AM

OracleSQL中的除法運算詳解在OracleSQL中,除法運算是一種常見且重要的數學運算運算,用來計算兩個數相除的結果。除法在資料庫查詢中經常用到,因此了解OracleSQL中的除法運算及其用法是資料庫開發人員必備的技能之一。本文將詳細討論OracleSQL中除法運算的相關知識,並提供具體的程式碼範例供讀者參考。一、OracleSQL中的除法運算

PHP模運算子的作用及用法詳解 PHP模運算子的作用及用法詳解 Mar 19, 2024 pm 04:33 PM

PHP中的模運算子(%)是用來取得兩個數值相除的餘數的。在本文中,我們將詳細討論模運算子的作用及用法,並提供具體的程式碼範例來幫助讀者更好地理解。 1.模運算子的作用在數學中,當我們將一個整數除以另一個整數時,就會得到一個商和一個餘數。例如,當我們將10除以3時,商數為3,餘數為1。模運算子就是用來取得這個餘數的。 2.模運算子的用法在PHP中,使用%符號來表示模

linux系統呼叫system()函數詳解 linux系統呼叫system()函數詳解 Feb 22, 2024 pm 08:21 PM

Linux系統呼叫system()函數詳解系統呼叫是Linux作業系統中非常重要的一部分,它提供了一種與系統核心互動的方式。其中,system()函數是常用的系統呼叫函數之一。本文將詳細介紹system()函數的使用方法,並提供對應的程式碼範例。系統呼叫的基本概念系統呼叫是使用者程式與作業系統核心互動的一種方式。使用者程式透過呼叫系統呼叫函數來請求作業系統

Linux的curl指令詳解 Linux的curl指令詳解 Feb 21, 2024 pm 10:33 PM

Linux的curl命令詳解摘要:curl是一種強大的命令列工具,用於與伺服器進行資料通訊。本文將介紹curl指令的基本用法,並提供實際的程式碼範例,幫助讀者更好地理解和應用該指令。一、curl是什麼? curl是命令列工具,用於發送和接收各種網路請求。它支援多種協議,如HTTP、FTP、TELNET等,並提供了豐富的功能,如檔案上傳、檔案下載、資料傳輸、代

深入了解Promise.resolve() 深入了解Promise.resolve() Feb 18, 2024 pm 07:13 PM

Promise.resolve()詳解,需要具體程式碼範例Promise是JavaScript中一種用來處理非同步操作的機制。在實際開發中,常常需要處理一些需要依序執行的非同步任務,而Promise.resolve()方法就是用來傳回一個已經Fulfilled狀態的Promise物件。 Promise.resolve()是Promise類別的靜態方法,它接受一個

numpy版本查詢方法詳解 numpy版本查詢方法詳解 Jan 19, 2024 am 08:20 AM

Numpy是一款Python科學計算庫,提供了豐富的陣列操作函數與工具。升級Numpy版本時需要查詢目前版本以確保相容性,本文將詳細介紹Numpy版本查詢的方法,並提供具體的程式碼範例。方法一:使用Python程式碼查詢Numpy版本使用Python程式碼可以輕鬆查詢Numpy的版本,以下是實作方法和範例程式碼:importnumpyasnpprint(np

詳細解析C語言學習路線 詳細解析C語言學習路線 Feb 18, 2024 am 10:38 AM

C語言作為一門廣泛應用在軟體開發領域的程式語言,是許多程式設計師初學者的首選。學習C語言不僅可以幫助我們建立程式設計的基礎知識,還可以提升我們解決問題和思考的能力。本文將詳細介紹一條C語言學習的路線圖,幫助初學者更好地規劃自己的學習進度。 1.學習基本文法在開始學習C語言之前,我們首先需要先了解C語言的基本文法規則。這包括變數和資料類型、運算子、控制語句(如if語句、

See all articles