vue學習——模板語法

Vue.js 使用了基於 HTML 的模板語法,允許開發者聲明式地將 DOM 綁定至底層組件實例的數據。所有 Vue.js 的模板都是合法的 HTML,所以能被遵循規範的瀏覽器和 HTML 解析器解析。

在底層的實現上,Vue 將模板編譯成虛擬 DOM 渲染函數。結合響應性系統,Vue 能夠智能地計算出最少需要重新渲染多少組件,並把 DOM 操作次數減到最少。

如果你熟悉虛擬 DOM 並且偏愛 JavaScript 的原始力量,你也可以不用模板,直接寫渲染 (render) 函數,使用可選的 JSX 語法

插值

文本

數據綁定最常見的形式就是使用“Mustache” (雙大括號) 語法的文本插值:

<span>Message: {{ msg }}</span>

Mustache 標籤將會被替代爲對應組件實例中 msg property 的值。無論何時,綁定的組件實例上 msg property 發生了改變,插值處的內容都會更新

通過使用 v-once 指令,你也能執行一次性地插值,當數據改變時,插值處的內容不會更新。但請留心這會影響到該節點上的其它數據綁定:

<span v-once>這個將不會改變: {{ msg }}</span>

原始 HTML

雙大括號會將數據解釋爲普通文本,而非 HTML 代碼。爲了輸出真正的 HTML,你需要使用v-html 指令

<p>Using mustaches: {{ rawHtml }}</p>
<p>Using v-html directive: <span v-html="rawHtml"></span></p>

這個 span 的內容將會被替換成爲 rawHtml property 的值,直接作爲 HTML——會忽略解析 property 值中的數據綁定。注意,你不能使用 v-html 來複合局部模板,因爲 Vue 不是基於字符串的模板引擎。反之,對於用戶界面 (UI),組件更適合作爲可重用和可組合的基本單位。

TIP

在你的站點上動態渲染任意的 HTML 是非常危險的,因爲它很容易導致 XSS 攻擊。請只對可信內容使用 HTML 插值,絕不要將用戶提供的內容作爲插值。

Attribute

Mustache 語法不能在 HTML attribute 中使用,然而,可以使用 v-bind 指令

<div v-bind:id="dynamicId"></div>

如果綁定的值是 null 或 undefined,那麼該 attribute 將不會被包含在渲染的元素上。

對於布爾 attribute (它們只要存在就意味着值爲 true),v-bind 工作起來略有不同,在這個例子中:

<button v-bind:disabled="isButtonDisabled">按鈕</button>

如果 isButtonDisabled 的值是 truthy[1],那麼 disabled attribute 將被包含在內。如果該值是一個空字符串,它也會被包括在內,與 <button disabled=""> 保持一致。對於其他 falsy[2] 的值,該 attribute 將被省略。

使用 JavaScript 表達式

迄今爲止,在我們的模板中,我們一直都只綁定簡單的 property 鍵值。但實際上,對於所有的數據綁定,Vue.js 都提供了完全的 JavaScript 表達式支持

{{ number + 1 }}
{{ ok ? 'YES' : 'NO' }}
{{ message.split('').reverse().join('') }}
<div v-bind:id="'list-' + id"></div>

這些表達式會在當前活動實例的數據作用域下作爲 JavaScript 被解析。有個限制就是,每個綁定都只能包含單個表達式,所以下面的例子都不會生效。

<!--  這是語句,不是表達式:-->
{{ var a = 1 }}

<!-- 流程控制也不會生效,請使用三元表達式 -->
{{ if (ok) { return message } }}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章