溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

vue.js中的常用指令有哪些

發(fā)布時間:2021-01-21 11:00:24 來源:億速云 閱讀:138 作者:小新 欄目:編程語言

這篇文章給大家分享的是有關(guān)vue.js中的常用指令有哪些的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

v-text

v-text主要用來更新textContent,可以等同于JS的text屬性。

<span v-text="text"></span>
// 等同于下方語句: 
<span>{{text}}</span>

v-html

雙大括號的方式會將數(shù)據(jù)解釋為純文本,而非HTML。為了輸出真正的HTML,可以用v-html指令。它等同于JS的 innerHtml 屬性。

注意:內(nèi)容按普通 HTML 插入 - 不會作為 Vue 模板進(jìn)行編譯 。

<div v-html="html"></div>

v-show

等同于 css 的 dispaly 屬性切換 “none” 和 “block” 設(shè)值。

<div v-show="isShow">hello world</div>

v-if

v-if可以實現(xiàn)條件渲染,Vue會根據(jù)表達(dá)式的值的真假條件來渲染元素。

<div v-show="isShow">hello world</div>

上方代碼,如果 isShow 為 false 則div被渲染,否則不被渲染。

注意:

v-if 需要和 v-show 區(qū)分開,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的時候顯示的內(nèi)容</div>
<div v-else>值為false的時候顯示的內(nèi)容</div>

v-else-if

v-else-if充當(dāng)v-if的else-if塊,可以鏈?zhǔn)降氖褂枚啻巍?類似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指令根據(jù)遍歷數(shù)組來進(jìn)行渲染。

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

// 補充:
// 也可以自行指定參數(shù),最多可以接受3個參數(shù)
<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>

// 迭代整數(shù)
<ul>
    <li v-for="n in 10">
     {{ n }}
    </li>
</ul>

v-on

綁定事件監(jiān)聽器。事件類型由參數(shù)指定。表達(dá)式可以是一個方法的名字或一個內(nèi)聯(lián)語句,如果沒有修飾符也可以省略。
v-on 也可以簡寫為 " @ ",如:

v-on="show" 可以簡寫為: @show

<!-- 方法處理器 -->
<button v-on:click="doThis"></button>

<!-- 動態(tài)事件 (2.6.0+) -->
<button v-on:[event]="doThis"></button>

<!-- 內(nèi)聯(lián)語句 -->
<button v-on:click="doThat('hello', $event)"></button>

<!-- 縮寫 -->
<button @click="doThis"></button>

<!-- 動態(tài)事件縮寫 (2.6.0+) -->
<button @[event]="doThis"></button>

<!-- 停止冒泡 -->
<button @click.stop="doThis"></button>

<!-- 阻止默認(rèn)行為 -->
<button @click.prevent="doThis"></button>

<!-- 阻止默認(rèn)行為,沒有表達(dá)式 -->
<form @submit.prevent></form>

<!--  串聯(lián)修飾符 -->
<button @click.stop.prevent="doThis"></button>

<!-- 鍵修飾符,鍵別名 -->
<input @keyup.enter="onEnter">

<!-- 鍵修飾符,鍵代碼 -->
<input @keyup.13="onEnter">

<!-- 點擊回調(diào)只會觸發(fā)一次 -->
<button v-on:click.once="doThis"></button>

<!-- 對象語法 (2.4.0+) -->
<button v-on="{ mousedown: doThis, mouseup: doThat }"></button>

還可以使用修飾符,具體如下:

.stop - 調(diào)用 event.stopPropagation()。

.prevent - 調(diào)用 event.preventDefault()。

.capture - 添加事件偵聽器時使用 capture 模式。

.self - 只當(dāng)事件是從偵聽器綁定的元素本身觸發(fā)時才觸發(fā)回調(diào)。

.{keyCode | keyAlias} - 只當(dāng)事件是從特定鍵觸發(fā)時才觸發(fā)回調(diào)。

.native - 監(jiān)聽組件根元素的原生事件。

.once - 只觸發(fā)一次回調(diào)。

.left - 只當(dāng)點擊鼠標(biāo)左鍵時觸發(fā)。

.right - 只當(dāng)點擊鼠標(biāo)右鍵時觸發(fā)。

.middle - 只當(dāng)點擊鼠標(biāo)中鍵時觸發(fā)。

.passive - 以 { passive: true } 模式添加偵聽器

v-bind

動態(tài)地綁定一個或多個特性,或一個組件 prop 到表達(dá)式。常用于動態(tài)綁定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>

//渲染結(jié)果為: <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>

//渲染結(jié)果為: <div class="active error"></div>

其他實例,具體見下方代碼:

<!-- 綁定一個屬性 -->
<img v-bind:src="imageSrc">

<!-- 動態(tài)特性名 (2.6.0+) -->
<button v-bind:[key]="value"></button>

<!-- 縮寫 -->
<img :src="imageSrc">

<!-- 動態(tài)特性名縮寫 (2.6.0+) -->
<button :[key]="value"></button>

<!-- 內(nèi)聯(lián)字符串拼接 -->
<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 綁定?!皃rop”必須在 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

在表單控件或者組件上創(chuàng)建雙向綁定。
v-model會忽略所有表單元素的value、checked、selected特性的初始值。因為它選擇Vue實例數(shù)據(jù)做為具體的值。

<div id="app">
  <input v-model="somebody">
  <p>hello {{somebody}}</p>
</div>
<script>
  var app = new Vue({
    el: '#app',
    data: {
      somebody:'小明'
    }
  })
</script>

這個例子中直接在瀏覽器input中輸入別的名字,下面的p的內(nèi)容會直接跟著變。這就是雙向數(shù)據(jù)綁定。

可用修飾符:

.lazy - 默認(rèn)情況下,v-model同步輸入框的值和數(shù)據(jù)??梢酝ㄟ^這個修飾符,轉(zhuǎn)變?yōu)樵赾hange事件再同步。

.number - 自動將用戶的輸入值轉(zhuǎn)化為數(shù)值類型

.trim - 自動過濾用戶輸入的首尾空格

修飾符使用方法:如:

<input v-model.trim="somebody">

v-pre

v-pre主要用來跳過這個元素和它的子元素編譯過程??梢杂脕盹@示原始的Mustache標(biāo)簽。跳過大量沒有指令的節(jié)點加快編譯。

<div id="app">
  <span v-pre>{{message}}</span> //這條語句不進(jìn)行編譯
  <span>{{message}}</span>
</div>

這個指令是用來保持在元素上直到關(guān)聯(lián)實例結(jié)束時進(jìn)行編譯。

<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指令可以解決上面插值閃爍的問題,如下:其實利用的就是當(dāng)插值沒有被加載出來的是通過 style屬性將內(nèi)容給隱藏了。

  <style>
    [v-cloak] {
       display: none; 
    }
  </style>
  
  <div id="app">
    <!-- 使用 v-cloak 能夠解決 插值表達(dá)式閃爍的問題 -->
    <p v-cloak>++++++++ {{ msg }} ----------</p>
  </div>
  
  <script>
    var vm = new Vue({
      el: '#app',
      data: {
        msg: 'hello',
      }
    })
  </script>

v-once

v-once關(guān)聯(lián)的實例,只會渲染一次。之后的重新渲染,實例極其所有的子節(jié)點將被視為靜態(tài)內(nèi)容跳過,這可以用于優(yōu)化更新性能。

<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即使產(chǎn)生改變,也不會重新渲染。

v-slot

提供具名插槽或需要接收 prop 的插槽。

可簡寫為:#

slot 和 scope-slot 是在 vue@2.6.x 之前的語法,而從 vue@2.6.0 開始,官方推薦我們使用 v-slot 來替代前兩者。

使用具名插槽來自定義模板內(nèi)容(vue@2.6.x已經(jīng)廢棄)

<div class="container">
  <header>
    <slot name="header"></slot>
  </header>
  <main>
    <slot></slot>
  </main>
  <footer>
    <slot name="footer"></slot>
  </footer>
</div>

在向具名插槽提供內(nèi)容的時候,我們可以在一個父組件的 元素上使用 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>

感謝各位的閱讀!關(guān)于“vue.js中的常用指令有哪些”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI