欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue2.0自定義指令示例代碼詳解

 更新時間:2019年04月25日 11:28:44   作者:_Junjun  
指令通常以"v-"作為前綴, 以方便Vue知道你在使用一種特殊的標(biāo)記。這篇文章主要介紹了vue2.0自定義指令的實例代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下

1、什么是指令?

指令通常以"v-"作為前綴, 以方便Vue知道你在使用一種特殊的標(biāo)記。

除了 Vue 核心攜帶著的一些默認(rèn)指令(v-model 和 v-show)之外,

Vue 還允許你注冊自己的自定義指令。某些情況下,還是需要對普通元素進(jìn)行一些底層 DOM 訪問,

這也是自定義指令仍然有其使用場景之處。

2、全局指令:

當(dāng)頁面加載時,元素將獲取焦點,事實上,在訪問頁面時,如果你還沒有點擊任何地方,上面的輸入框現(xiàn)在應(yīng)該處于獲取焦點的狀態(tài)。現(xiàn)在讓我們構(gòu)建指令以完成此效果:

<template>
<div class="parent">
 <input v-focus>
</div>
</template>
import Vue from 'vue'
 import cnChildren from './children'
 // 注冊一個名為 `v-focus` 的全局自定義指令
 Vue.directive('focus', {
  // 當(dāng)綁定的元素插入到 DOM 時調(diào)用此函數(shù)……
  inserted: function (el) {
   // 元素調(diào)用 focus 獲取焦點
   el.focus()
  }
 });

如果你想要注冊一個局部指令,也可以通過設(shè)置組件的 directives 選項:

directives: {
 focus: {
  // 指令定義對象
  inserted: function (el) {
   el.focus()
  }
 }
}

我們有幾個可用的鉤子:

bind:在指令第一次綁定到元素時調(diào)用,只會調(diào)用一次。可以在此鉤子函數(shù)中,執(zhí)行一次性的初始化設(shè)置。
inserted:在已綁定的元素插入到父節(jié)點時調(diào)用(只能保證父節(jié)點存在,不一定存在于 document 中)。
update:在包含指令的組件的 VNode 更新后調(diào)用,但可能之前其子組件已更新。指令的值可能更新或者還沒更新,然而可以通過比較綁定的當(dāng)前值和舊值,來跳過不必要的更新(參考下面的鉤子函數(shù))。
componentUpdated:在包含指令的組件的 VNode 更新后調(diào)用,并且其子組件的 VNode 已更新。
unbind:在指令從元素上解除綁定時調(diào)用,只會調(diào)用一次。
每個鉤子可以選擇一些參數(shù)。

el:指令綁定的元素??梢杂糜谥苯硬僮?DOM。

binding:一個對象,包含以下屬性:

1、name:指令的名稱,不包括 v- 前綴。
  2、value:向指令傳入的值。例如,在 v-my-directive="1 + 1" 中,傳入的值是 2。
  3、oldValue:之前的值,只在 update 和 componentUpdated 鉤子函數(shù)中可用。無論值是否發(fā)生變化,都可以使用。
  4、expression:指令綁定的表達(dá)式(expression),以字符串格式。例如,在 v-my-directive="1 + 1" 中,表達(dá)式是 "1 + 1"。
  5、arg:向指令傳入的參數(shù),如果有的話。例如,在 v-my-directive:foo 中,參數(shù)是 "foo"。
  6、modifiers:一個對象,包含修飾符,如果有的話。例如,在 v-my-directive.foo.bar 中,修飾符是 { foo: true, bar: true }。
vnode:由 Vue 編譯器(Vue's compiler)生成的虛擬 Node 節(jié)點(virtual node)。更多細(xì)節(jié)請查看
VNode API。

除了 el 之外的其他參數(shù),都應(yīng)該是只讀的,并且永遠(yuǎn)不要去修改它們。

3、自定義指令示例

如果指令需要多個值,你還可以向指令傳入 JavaScript 對象字面量(object literal)。記住,指令能夠接收所有有效的 JavaScript 表達(dá)式。

<div v-demo="{ color: 'white', text: 'hello!' }"></div>
Vue.directive('demo', function (el, binding) {
 console.log(binding.value.color) // => "white"
 console.log(binding.value.text) // => "hello!"
})

總結(jié)

以上所述是小編給大家介紹的vue2.0自定義指令示例代碼詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • 解決ant Design Search無法輸入內(nèi)容的問題

    解決ant Design Search無法輸入內(nèi)容的問題

    這篇文章主要介紹了解決ant Design Search無法輸入內(nèi)容的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • vue單文件組件的實現(xiàn)

    vue單文件組件的實現(xiàn)

    最近翻閱了一下vue。發(fā)覺有一個單文件組件之前基本忽視掉了。所以本文就詳細(xì)的介紹了vue單文件組件的實現(xiàn),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • 淺談element關(guān)于table拖拽排序問題

    淺談element關(guān)于table拖拽排序問題

    本文主要介紹了element關(guān)于table拖拽排序問題,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 如何使用Vue3實現(xiàn)文章內(nèi)容中多個"關(guān)鍵詞"標(biāo)記高亮顯示

    如何使用Vue3實現(xiàn)文章內(nèi)容中多個"關(guān)鍵詞"標(biāo)記高亮顯示

    高亮顯示是我們?nèi)粘i_發(fā)中經(jīng)常會遇到的需求,下面這篇文章主要給大家介紹了關(guān)于如何使用Vue3實現(xiàn)文章內(nèi)容中多個"關(guān)鍵詞"標(biāo)記高亮顯示的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • Vue通過ref獲取dom元素屬性的方法

    Vue通過ref獲取dom元素屬性的方法

    這篇文章主要介紹了Vue通過ref獲取dom元素屬性的方法,文中有詳細(xì)的方法介紹,對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2023-11-11
  • uniapp中使用u-loadmore,loadText內(nèi)容不隨status改變刷新方式

    uniapp中使用u-loadmore,loadText內(nèi)容不隨status改變刷新方式

    這篇文章主要介紹了uniapp中使用u-loadmore,loadText內(nèi)容不隨status改變刷新方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • 前端vue-cropperjs實現(xiàn)圖片裁剪方案

    前端vue-cropperjs實現(xiàn)圖片裁剪方案

    這篇文章主要為大家介紹了前端vue-cropperjs實現(xiàn)圖片裁剪方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • vue2.0實現(xiàn)列表數(shù)據(jù)增加和刪除

    vue2.0實現(xiàn)列表數(shù)據(jù)增加和刪除

    這篇文章主要為大家詳細(xì)介紹了vue2.0實現(xiàn)列表數(shù)據(jù)增加和刪除,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • 如何在vue3中優(yōu)雅的使用jsx/tsx詳解

    如何在vue3中優(yōu)雅的使用jsx/tsx詳解

    看了一些 Vue3 的組件庫源碼,發(fā)現(xiàn)無一例外都使用的jsx/tsx來實現(xiàn),而且實現(xiàn)方式也各不相同,下面這篇文章主要給大家介紹了關(guān)于如何在vue3中優(yōu)雅的使用jsx/tsx的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • Vue3計算屬性是如何實現(xiàn)的

    Vue3計算屬性是如何實現(xiàn)的

    這篇文章主要介紹了Vue3計算屬性是如何實現(xiàn)的,對于任何包含響應(yīng)式數(shù)據(jù)的復(fù)雜邏輯,我們都應(yīng)該使用計算屬性,更多相關(guān)內(nèi)容需要的小伙伴可以參考一下
    2022-08-08

最新評論