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

簡單學習vue指令directive

 更新時間:2021年08月27日 14:35:59   作者:Stevenzhai  
這篇文章主要和大家一起簡單學習一下vue指令:directive,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文為大家分享了vue指令directive的使用方法,供大家參考,具體內(nèi)容如下

1.指令的注冊

指令跟組件一樣需要注冊才能使用,同樣有兩種方式,一種是全局注冊:

Vue.directive('dirName',function(){

  //定義指令

});

另外一種是局部注冊:

new Vue({

  directives:{

    dirName:{

      //定義指令

    }

  }

});

2.指令的定義

指令定義,官方提供了五個鉤子函數(shù)來供我們使用,分別代表了一個組件的各個生命周期

bind: 只調(diào)用一次,指令第一次綁定到元素時調(diào)用,用這個鉤子函數(shù)可以定義一個在綁定時執(zhí)行一次的初始化動作。

inserted: 被綁定元素插入父節(jié)點時調(diào)用(父節(jié)點存在即可調(diào)用,不必存在于 document 中)。

update: 被綁定元素所在的模板更新時調(diào)用,而不論綁定值是否變化。通過比較更新前后的綁定值,可以忽略不必要的模板更新(詳細的鉤子函數(shù)參數(shù)見下)。

componentUpdated: 被綁定元素所在模板完成一次更新周期時調(diào)用。

unbind: 只調(diào)用一次, 指令與元素解綁時調(diào)用。

在這里其他幾個都好理解,關(guān)于模板更新(update)這里,本人的理解是:該指令所在的模板有變化而需要重新渲染的時候,比如當一個輸入框的model發(fā)生了變化就會觸發(fā)指令。當然此處說的比較模糊,具體的還有待研究。

這段代碼可以實現(xiàn)關(guān)于update的使用

<div id="app">
  <input type="text" v-focus="name" v-model="name" :data-name="name">
  <button type="button" @click="name='zw'">click</button>

  <!--當點擊按鈕的時候name改變,繼而觸發(fā)update中的方法-->
</div>
<script>

  Vue.directive('focus',{
    bind: function(el, binding){
    console.log('bind:',binding.value);
  },
  inserted: function(el, binding){
    console.log('insert:',binding.value);
  },
  update: function(el, binding, vnode, oldVnode){
    el.focus();
    console.log(el.dataset.name);//這里的數(shù)據(jù)是可以動態(tài)綁定的
    console.table({
      name:binding.name,
      value:binding.value,
      oldValue:binding.oldValue,
      expression:binding.expression,
      arg:binding.arg,
      modifiers:binding.modifiers,
      vnode:vnode,
      oldVnode:oldVnode
    });
  },
  componentUpdated: function(el, binding){
    console.log('componentUpdated:',binding.name);
  }
});
new Vue({
  el:'#app',
  data:{
    name:'zwzhai'
  }
});
</script>

3.鉤子函數(shù)的定義

以下是官方提供的幾個參數(shù):

el: 指令所綁定的元素,可以用來直接操作 DOM 。
binding: 一個對象,包含以下屬性:
name: 指令名,不包括 v- 前綴。
value: 指令的綁定值, 例如: v-my-directive="1 + 1", value 的值是 2。
oldValue: 指令綁定的前一個值,僅在 update 和 componentUpdated 鉤子中可用。無論值是否改變都可用。
expression: 綁定值的字符串形式。 例如 v-my-directive="1 + 1" , expression 的值是 "1 + 1"。
arg: 傳給指令的參數(shù)。例如 v-my-directive:foo, arg 的值是 "foo"。
modifiers: 一個包含修飾符的對象。 例如: v-my-directive.foo.bar, 修飾符對象 modifiers 的值是{ foo: true, bar: true }。
vnode: Vue 編譯生成的虛擬節(jié)點,查閱 VNode API 了解更多詳情。
oldVnode: 上一個虛擬節(jié)點,僅在 update 和 componentUpdated 鉤子中可用。

這幾個參數(shù),大家看文檔也能理解,就不多說了,關(guān)于bingding的幾個屬性說一下自己的看法,value這個屬性,可以傳字面量,也可以傳單條語句(如上),還可以以變量的形式如<input type="text" v-focus="name" v-model="name">;arg這里可以傳一個字符串,因為在value去訪問綁定值得時候拿到的不是直接寫的那個,也就是說v-focus="name",這個name永遠都是一個變量,需要定義賦值,而arg可以直接訪問該值,如v-focus:foo,那么在鉤子函數(shù)中拿到的就是foo這個字符串。

在vue的指令中是不可以雙向數(shù)據(jù)綁定的,如官方所說:除了 el 之外,其它參數(shù)都應該是只讀的,盡量不要修改他們。如果需要在鉤子之間共享數(shù)據(jù),建議通過元素的 dataset 來進行。這里補充下關(guān)于dataset的知識:

data-  是html5的一個新屬性,查了下瀏覽器支持程度,目前的主流瀏覽器都是支持的,IE的話要到10以上。具體的使用:在HTML中以屬性的方式去寫,data-yourname="value",在js中取這個屬性就不用使用getAttribute這個方法,而是直接訪問,ele.dataset.yourname,在js中你也可以添加和刪除,添加:ele.dataset.dessert="yourname",刪除:dette ele.dataset.name。此外,這個屬性可以用作css選擇器:.class[data-name]:{}。

最后附上自己寫的一個vue小程序,簡單的頁面切換,使用vue-cli構(gòu)建,sample的簡單版,還使用的mint-ui組件庫,git地址:https://github.com/Stevenzwzhai/news-vue

本文已被整理到了《Vue.js前端組件學習教程》,歡迎大家學習閱讀。

 以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue組件之全局組件與局部組件的使用詳解

    Vue組件之全局組件與局部組件的使用詳解

    本篇文章主要介紹了Vue組件之全局組件與局部組件的使用詳解,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • vue自動化路由的實現(xiàn)代碼

    vue自動化路由的實現(xiàn)代碼

    這篇文章主要介紹了vue自動化路由的實現(xiàn)代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-09-09
  • Vue 使用超圖SuperMap的實踐

    Vue 使用超圖SuperMap的實踐

    作為一名剛?cè)腴T計算機語言的人來說,要想快速完成測試開發(fā)地圖項目,肯定要接用到SuperMap,本文主要介紹了Vue 使用超圖SuperMap的實踐,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • 詳解vue.js移動端導航navigationbar的封裝

    詳解vue.js移動端導航navigationbar的封裝

    本篇文章主要介紹了vue.js移動端導航navigationbar的封裝,具有一定的參考價值,有興趣的可以了解一下
    2017-07-07
  • vue樹形結(jié)構(gòu)數(shù)據(jù)處理的方法總結(jié)

    vue樹形結(jié)構(gòu)數(shù)據(jù)處理的方法總結(jié)

    在項目開發(fā)的過程中,會經(jīng)常使用樹形結(jié)構(gòu)數(shù)據(jù),前后端交互都會對數(shù)據(jù)進行處理,后端返回的數(shù)據(jù)前端有的時候不能直接使用需要轉(zhuǎn)換,本文小編整理了一些項目中用到的處理方法,需要的朋友可以參考下
    2023-11-11
  • element-ui循環(huán)顯示radio控件信息的方法

    element-ui循環(huán)顯示radio控件信息的方法

    今天小編就為大家分享一篇element-ui循環(huán)顯示radio控件信息的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • VueJs監(jiān)聽window.resize方法示例

    VueJs監(jiān)聽window.resize方法示例

    本篇文章主要介紹了VueJs監(jiān)聽window.resize方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • Vue手寫實現(xiàn)組件初渲染

    Vue手寫實現(xiàn)組件初渲染

    這篇文章主要介紹了Vue手寫實現(xiàn)組件初渲染,在Vue進行文本編譯之后,會得到代碼字符串生成的render函數(shù),本文會基于render函數(shù)展開主題相關(guān)內(nèi)容,感興趣的朋友可以參考一下
    2022-08-08
  • Ant-design-vue Table組件customRow屬性的使用說明

    Ant-design-vue Table組件customRow屬性的使用說明

    這篇文章主要介紹了Ant-design-vue Table組件customRow屬性的使用說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • 當vue路由變化時,改變導航欄的樣式方法

    當vue路由變化時,改變導航欄的樣式方法

    今天小編就為大家分享一篇當vue路由變化時,改變導航欄的樣式方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08

最新評論