您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關Vue.js中有哪些常用的模板語法,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
一、文本渲染
Vue支持動態渲染文本,即在修改屬性的同時,實時渲染文本內容。同時為了提高渲染效率,也支持只渲染一次,即第一次渲染出文本后,文本內容不再跟隨屬性值的變化而變化。
實時渲染
<div class="row"> <h3>文本 - 實時渲染</h3> <input type="text" v-model="msg" class="col-md-2" /> <span class="col-md-">{{ msg }}</span> </div>
v-model 指令將 input 標簽的值動態綁定到屬性 msg 上,通過 {{ msg }} 表達式顯示在頁面上。當修改文本框內容時,后面的頁面內容將實時變化并與文本框內容保持一致。
一次渲染
<div class="row"> <h3>文本 - 一次渲染</h3> <input type="text" v-model="msg_once" class="col-md-2" /> <span class="col-md-" v-once>{{ msg_once }}</span> </div>
在 vm 對象里添加屬性
require(["jquery", "bootstrap", "vue"], function ($, bootstrap, Vue) { var vm = new Vue({ el: "#app", data: { msg_once: "once..." } }); });
頁面第一次加載完成時,頁面顯示once...,當 span 標簽加上 v-once 指令后,無論如何修改文本框內容,頁面內容都不會變化。
HTML代碼渲染
某些情況下,頁面需要動態的插入一段HTML代碼
在 vm 對象里添加屬性,屬性值為一段HTML代碼
require(["jquery", "bootstrap", "vue"], function ($, bootstrap, Vue) { var vm = new Vue({ el: "#app", data: { html: "<span>This is a html tag.</span>" } }); });
頁面元素添加 v-html
指令后,元素對應位置將顯示出屬性值內的對應元素
<div class="row"> <h3>文本 - HTML</h3> <div v-html="html"></div> </div>
二、表達式
上文中已經介紹過的 {{ msg }}
就是一個簡單的表達式。除此之外,還有一些常用的表達式寫法。
運算表達式
在上述簡單表達式中可以使用運算符,Vue會將運算后的結果渲染在頁面上
<div> <h5>運算表達式</h5> <span v-pre>{{ Number(number)+ }}:</span> <input v-model="number" type="text" /> <span>運算結果:{{ Number(number)+ }}</span> </div>
在文本框中輸入數字,Vue通過表達式內的運算符實時計算出結果,并顯示出來。因為文本框內容為字符串,所以在表達式中需要對 number 屬性進行類型轉換成數字。
三元運算表達式
Vue支持在表達式內使用三元運算符
<div> <h5>三元運算表達式</h5> <span v-pre>{{ ok ? 'YES' : 'NO' }}:</span><span>{{ ok ? 'YES' : 'NO' }}</span> </div>
Javascript方法
表達式內也可以使用Javascript支持的基礎方法,Vue會動態執行方法并顯示最終結果
<div> <h5>Javascript方法</h5> <span v-pre>{{msg_once.split('').reverse().join('')}}:</span><span>{{msg_once.split('').reverse().join('')}}</span> </div>
這個例子是將 msg_once 屬性值的字符進行倒序排列后重新組合起來。
三、過濾器
過濾器經常用來進行內容的格式化顯示。Vue支持自定義過濾器
首先要在 vm
對象里增加過濾器方法
require(["jquery", "bootstrap", "vue"], function ($, bootstrap, Vue) { var vm = new Vue({ el: "#app", data: { filter_msg: 'base' }, filters: { filter: function (value) { if (!value) { return ''; } return value + '_filter1'; }, filter2: function (value) { if (!value) { return ''; } return value + '_filter2'; }, filter_arg: function (value, arg1, arg2) { if (!value) { return ''; } return value + ' ' + arg1 + ' ' + arg2; } } }); });
所有的過濾器方法都要定義在 filters
屬性里,方法的第一個參數值就是傳遞進來需要被處理的原始內容,方法的返回值即時處理過的新內容。
自定義的過濾器使用方法如下
<div> <h5>單一過濾器</h5> <span v-pre>{{ filter_msg | filter1 }}:</span><span>{{ filter_msg | filter1 }}</span> </div>
上面的例子中,過濾器通過管道符號“|”與需要處理的內容進行連接,將 filter_msg
屬性值經過 filter1
過濾器,在后面追加內容并顯示。
同時,Vue也支持連接多個過濾器
<div> <h5>串聯過濾器</h5> <span v-pre>{{ filter_msg | filter1 | filter2 }}:</span><span>{{ filter_msg | filter1 | filter2 }}</span> </div>
這個例子中,通過管道符號“|”,可以連接多個過濾器,每前一個過濾器的輸出將作為后一個過濾器的輸入,直到顯示最終結果。
當過濾器有多個參數時,Vue也支持帶參數調用
<div> <h5>過濾器參數</h5> <span v-pre>{{ filter_msg | filter_arg('arg1', 'arg2') }}:</span><span>{{ filter_msg | filter_arg('arg1', 'arg2') }}</span> </div>
四、常用指令
指令就是將一些特殊行為應用到頁面DOM元素的特殊屬性。Vue的內置指令都是一些帶有 v- 前綴的特殊屬性。
常用的指令如下:
v-bind
v-on
v-for
v-if
v-else-if
v-else
v-show
v-bind
該指令用來給元素綁定一個或多個特性
<div> <h>v-bind(屬性綁定)</h> <span v-pre>可用的按鈕(v-bind:disabled="!btn_enabled"):</span><button v-bind:disabled="!btn_enabled" type="button">可以點擊的按鈕</button><br/> <span v-pre>不可用的按鈕(v-bind:disabled="btn_enabled"):</span><button v-bind:disabled="btn_enabled" type="button">不可點擊的按鈕</button><br/> <span v-pre>縮寫(:disabled="!btn_enabled"):</span><button :disabled="!btn_enabled" type="button">可以點擊的按鈕</button> </div>
require(["jquery", "bootstrap", "vue"], function ($, bootstrap, Vue) { var vm = new Vue({ el: "#app", data: { btn_enabled: true } }); });
在上面的例子里,給 vm 對象增加一個名稱為 btn_enabled 的布爾屬性,在按鈕中通過 v-bind:disabled="btn_enabled" 動態給 disabled 屬性賦值
頁面上可以看到“不能點擊的按鈕”動態增加了一個 disabled 屬性。同時 v-bind:disabled="!btn_enabled" 也可以簡寫成 :disabled="!btn_enabled" 。
v-on
該指令綁定事件監聽器。事件類型由參數指定。表達式可以是一個方法的名字或一個內聯語句。用在普通元素上時,只能監聽原生 DOM 事件。在監聽原生 DOM 事件時,方法以事件為唯一的參數。如果使用內聯語句,語句可以訪問一個 $event
屬性。
在 vm
對象的 methods
屬性里添加自定義方法
require(["jquery", "bootstrap", "vue"], function ($, bootstrap, Vue) { var vm = new Vue({ el: "#app", methods: { btn_click: function () { console.log("button click!"); }, btn_clickWithEvent: function($event){ console.log($event); }, btn_clickWithMsg: function (msg) { console.log("Message is:" + msg); } } }); });
通過屬性 v-on:click="btn_click"
在按鈕上添加 click
事件
<div> <h5>v-on(事件綁定)</h5> <span v-pre>點擊事件(v-on:click="btn_click"):</span><button v-on:click="btn_click" type="button">點我!</button><br/> <span v-pre>帶事件參數的點擊事件(v-on:click="btn_clickWithEvent($event)"):</span><button v-on:click="btn_clickWithEvent($event)" type="button">點我!</button><br/> <span v-pre>帶自定義參數的點擊事件(v-on:click="btn_clickWithMsg('Hello world!')"):</span><button v-on:click="btn_clickWithMsg('Hello world!')" type="button">點我!</button><br/> <span v-pre>縮寫(@click="btn_click"):</span><button @click="btn_click" type="button">點我!</button> </div>
頁面效果如下
v-on指令也支持縮寫,用@符號代替,比如: @click="btn_click"
。
v-for
該指令用來基于源數據多次渲染元素或模板塊。
在 vm 對象里添加一個數組類型的屬性 books
require(["jquery", "bootstrap", "vue"], function ($, bootstrap, Vue) { var vm = new Vue({ el: "#app", data: { books: ["深入淺出node", "C#本質論", "編程珠璣"] } }); });
通過 v-for 指令實現一個簡單列表
<div> <h5>v-for(循環)</h5> <ul> <li v-for="item in books"> {{ item }} </li> </ul> </div>
頁面效果如下
v-for 屬性值是一個 item in expression
結構的表達式,其中 item
代表 expression
運算結果的每一項。最終的HTML代碼如下
v-if、v-else-if、v-else
條件渲染指令,通過表達式結果的真假來插入和刪除元素。 v-if 可以單獨使用,而 v-else-if 、 v-else 必須和 v-if 一起使用。
下面是一個簡單用法的例子
<div> <h5>v-if、v-else-if、v-else(分支)</h5> <span>分支示例:</span> <input type="text" v-model="number" /> <span v-if="number>10">大于10</span> <span v-else-if="number==10">等于10</span> <span v-else>小于10</span><br/> </div>
頁面顯示如下
當文本框里輸入小于10的數字時,右側只顯示“小于10”的文本內容。
查看源碼發現,只有“小于10”的內容的 span 標簽存在,另外兩個標簽被插入到頁面中。
同樣,在輸入大于10的數字時,右側只顯示“大于10”的文本內容。而源碼里只有對應的 span 標簽存在。
v-show
該指令也是條件渲染指令,但是與上述的 v-if 有不同。這可以通過一個例子來說明。
<div> <h5>v-show(條件渲染)</h5> <span>v-show示例:</span> <input type="text" v-model="number" /> <span v-show="number>10">大于10</span> <span v-show="number==10">等于10</span> <span v-show="number<10">小于10</span><br/> </div>
將上面例子里的指令都換成 v-show ,頁面顯示如下
從頁面顯示的結果上看,沒有任何區別。但是查看源碼會發現,符合表達式結果判斷的元素內容將被顯示,不符合結果判斷的元素將被隱藏,即被加上 display: none; 的樣式。
從上面兩個例子對比可以看出
v-if:動態插入或刪除元素
v-show:動態顯示或隱藏元素
以上就是Vue.js中有哪些常用的模板語法,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。