您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關vue.js中的常用指令有哪些的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
v-text
v-text主要用來更新textContent,可以等同于JS的text屬性。
<span v-text="text"></span> // 等同于下方語句: <span>{{text}}</span>
v-html
雙大括號的方式會將數據解釋為純文本,而非HTML。為了輸出真正的HTML,可以用v-html指令。它等同于JS的 innerHtml 屬性。
注意:內容按普通 HTML 插入 - 不會作為 Vue 模板進行編譯 。
<div v-html="html"></div>
v-show
等同于 css 的 dispaly 屬性切換 “none” 和 “block” 設值。
<div v-show="isShow">hello world</div>
v-if
v-if可以實現條件渲染,Vue會根據表達式的值的真假條件來渲染元素。
<div v-show="isShow">hello world</div>
上方代碼,如果 isShow 為 false 則div被渲染,否則不被渲染。
注意:
v-if 需要和 v-show 區分開,v-show 的元素會始終被渲染并保存在 dom 中,它只是簡單的切換 css 的 dispaly 屬性。
v-if有更高的切換開銷。
v-show有更高的初始渲染開銷。
所以,如果要非常頻繁的切換,使用 v-show 較好;如果在運行時條件不太可能改變,使用 v-if 較好。
v-else
v-else 是搭配 v-if 使用的,它必須緊跟在 v-if 或者 v-else-if 后面,否則不起作用。
類似 JS 的 if .. else。
<div v-if="isSow">值為true的時候顯示的內容</div> <div v-else>值為false的時候顯示的內容</div>
v-else-if
v-else-if充當v-if的else-if塊,可以鏈式的使用多次。 類似JS的 if .. else if .. else
<div v-if="type==='A'"> A </div> <div v-if="type==='B'"> B </div> <div v-if="type==='C'"> C </div> <div v-else> Not A,B,C </div>
v-for
用v-for指令根據遍歷數組來進行渲染。
<ul> <li v-for="item in items">{{item.name}}</li> </ul> <script> new Vue({ el: '#app', data: { items: [ { name: 'Runoob' }, { name: 'Google' }, { name: 'Taobao' } ] } }) </script> // 補充: // 也可以自行指定參數,最多可以接受3個參數 <div v-for="(item, index) in items"></div> <div v-for="(val, key) in object"></div> <div v-for="(val, name, index) in object"></div> // 迭代對象 <ul> <li v-for="value in object"> {{ index }}. {{ key }} : {{ value }} </li> // 迭代整數 <ul> <li v-for="n in 10"> {{ n }} </li> </ul>
v-on
綁定事件監聽器。事件類型由參數指定。表達式可以是一個方法的名字或一個內聯語句,如果沒有修飾符也可以省略。
v-on 也可以簡寫為 " @ ",如:
v-on="show" 可以簡寫為: @show
<!-- 方法處理器 --> <button v-on:click="doThis"></button> <!-- 動態事件 (2.6.0+) --> <button v-on:[event]="doThis"></button> <!-- 內聯語句 --> <button v-on:click="doThat('hello', $event)"></button> <!-- 縮寫 --> <button @click="doThis"></button> <!-- 動態事件縮寫 (2.6.0+) --> <button @[event]="doThis"></button> <!-- 停止冒泡 --> <button @click.stop="doThis"></button> <!-- 阻止默認行為 --> <button @click.prevent="doThis"></button> <!-- 阻止默認行為,沒有表達式 --> <form @submit.prevent></form> <!-- 串聯修飾符 --> <button @click.stop.prevent="doThis"></button> <!-- 鍵修飾符,鍵別名 --> <input @keyup.enter="onEnter"> <!-- 鍵修飾符,鍵代碼 --> <input @keyup.13="onEnter"> <!-- 點擊回調只會觸發一次 --> <button v-on:click.once="doThis"></button> <!-- 對象語法 (2.4.0+) --> <button v-on="{ mousedown: doThis, mouseup: doThat }"></button>
還可以使用修飾符,具體如下:
.stop - 調用 event.stopPropagation()。
.prevent - 調用 event.preventDefault()。
.capture - 添加事件偵聽器時使用 capture 模式。
.self - 只當事件是從偵聽器綁定的元素本身觸發時才觸發回調。
.{keyCode | keyAlias} - 只當事件是從特定鍵觸發時才觸發回調。
.native - 監聽組件根元素的原生事件。
.once - 只觸發一次回調。
.left - 只當點擊鼠標左鍵時觸發。
.right - 只當點擊鼠標右鍵時觸發。
.middle - 只當點擊鼠標中鍵時觸發。
.passive - 以 { passive: true } 模式添加偵聽器
v-bind
動態地綁定一個或多個特性,或一個組件 prop 到表達式。常用于動態綁定class和style。以及href等。
可簡寫為:" : ",如:
v-bind:class=" isActive : 'active' :' ' ",可簡寫為::class=" isActive : 'active' :' ' "
<div v-bind:class=" isActive : 'active' :' ' "></div> <script> var app = new Vue({ el: '#app', data: { isActive : true, } }) </script> //渲染結果為: <div class="active"></div>
綁定多個 class ,具體如下:
<div v-bind:class="[ isActive : 'active' :' ' , isError: 'error' :' ' ]"> </div> <script> var app = new Vue({ el: '#app', data: { isActive : true, isError: true, } }) </script> //渲染結果為: <div class="active error"></div>
其他實例,具體見下方代碼:
<!-- 綁定一個屬性 --> <img v-bind:src="imageSrc"> <!-- 動態特性名 (2.6.0+) --> <button v-bind:[key]="value"></button> <!-- 縮寫 --> <img :src="imageSrc"> <!-- 動態特性名縮寫 (2.6.0+) --> <button :[key]="value"></button> <!-- 內聯字符串拼接 --> <img :src="'/path/to/images/' + fileName"> <!-- class 綁定 --> <div :class="{ red: isRed }"></div> <div :class="[classA, classB]"></div> <div :class="[classA, { classB: isB, classC: isC }]"> <!-- style 綁定 --> <div :style="{ fontSize: size + 'px' }"></div> <div :style="[styleObjectA, styleObjectB]"></div> <!-- 綁定一個有屬性的對象 --> <div v-bind="{ id: someProp, 'other-attr': otherProp }"></div> <!-- 通過 prop 修飾符綁定 DOM 屬性 --> <div v-bind:text-content.prop="text"></div> <!-- prop 綁定。“prop”必須在 my-component 中聲明。--> <my-component :prop="someThing"></my-component> <!-- 通過 $props 將父組件的 props 一起傳給子組件 --> <child-component v-bind="$props"></child-component> <!-- XLink --> <svg><a :xlink:special="foo"></a></svg>
v-model
在表單控件或者組件上創建雙向綁定。
v-model會忽略所有表單元素的value、checked、selected特性的初始值。因為它選擇Vue實例數據做為具體的值。
<div id="app"> <input v-model="somebody"> <p>hello {{somebody}}</p> </div> <script> var app = new Vue({ el: '#app', data: { somebody:'小明' } }) </script>
這個例子中直接在瀏覽器input中輸入別的名字,下面的p的內容會直接跟著變。這就是雙向數據綁定。
可用修飾符:
.lazy - 默認情況下,v-model同步輸入框的值和數據。可以通過這個修飾符,轉變為在change事件再同步。
.number - 自動將用戶的輸入值轉化為數值類型
.trim - 自動過濾用戶輸入的首尾空格
修飾符使用方法:如:
<input v-model.trim="somebody">
v-pre
v-pre主要用來跳過這個元素和它的子元素編譯過程。可以用來顯示原始的Mustache標簽。跳過大量沒有指令的節點加快編譯。
<div id="app"> <span v-pre>{{message}}</span> //這條語句不進行編譯 <span>{{message}}</span> </div>
這個指令是用來保持在元素上直到關聯實例結束時進行編譯。
<div id="app" v-cloak> <div> {{message}} </div> </div> <script type="text/javascript"> new Vue({ el:'#app', data:{ message:'hello world' } }) </script>
解釋:
在頁面加載時會閃爍,先顯示:
<div> {{message}} </div>
然后才會編譯為:
<div> hello world! </div>
v-cloak指令可以解決上面插值閃爍的問題,如下:其實利用的就是當插值沒有被加載出來的是通過 style屬性將內容給隱藏了。
<style> [v-cloak] { display: none; } </style> <div id="app"> <!-- 使用 v-cloak 能夠解決 插值表達式閃爍的問題 --> <p v-cloak>++++++++ {{ msg }} ----------</p> </div> <script> var vm = new Vue({ el: '#app', data: { msg: 'hello', } }) </script>
v-once
v-once關聯的實例,只會渲染一次。之后的重新渲染,實例極其所有的子節點將被視為靜態內容跳過,這可以用于優化更新性能。
<span v-once>This will never change:{{msg}}</span> //單個元素 <div v-once>//有子元素 <h2>comment</h2> <p>{{msg}}</p> </div> <my-component v-once:comment="msg"></my-component> //組件 <ul> <li v-for="i in list">{{i}}</li> </ul>
上面的例子中,msg,list即使產生改變,也不會重新渲染。
v-slot
提供具名插槽或需要接收 prop 的插槽。
可簡寫為:#
slot 和 scope-slot 是在 vue@2.6.x 之前的語法,而從 vue@2.6.0 開始,官方推薦我們使用 v-slot 來替代前兩者。
使用具名插槽來自定義模板內容(vue@2.6.x已經廢棄)
<div class="container"> <header> <slot name="header"></slot> </header> <main> <slot></slot> </main> <footer> <slot name="footer"></slot> </footer> </div>
在向具名插槽提供內容的時候,我們可以在一個父組件的 元素上使用 slot 特性:
<base-layout> <template slot="header"> <h2>Here might be a page title</h2> </template> <p>A paragraph for the main content.</p> <p>And another one.</p> <template slot="footer"> <p>Here's some contact info</p> </template> </base-layout>
接下來,使用 v-slot 指令改寫上面的栗子:
<base-layout> <template v-slot:header> <h2>Here might be a page title</h2> </template> <p>A paragraph for the main content.</p> <p>And another one.</p> <template v-slot:footer> <p>Here's some contact info</p> </template> </base-layout>
使用 # 簡寫代替 v-slot
<base-layout> <template #header> <h2>Here might be a page title</h2> </template> <p>A paragraph for the main content.</p> <p>And another one.</p> <template #footer> <p>Here's some contact info</p> </template> </base-layout>
感謝各位的閱讀!關于“vue.js中的常用指令有哪些”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。