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

Vue.js自定義指令學(xué)習(xí)使用詳解

 更新時(shí)間:2019年10月19日 08:54:49   作者:吳聲子夜歌  
這篇文章主要為大家詳細(xì)介紹了Vue.js自定義指令的使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

自定義指令

自定義指令的注冊方法和組件很像,也分全局注冊和局部注冊,比如注冊一個(gè)v-focus指令用于在<input>、<textarea>元素初始化時(shí)自動獲得焦點(diǎn),共有兩種寫法:

//全局注冊
Vue.directive('focus',{
 //指令選項(xiàng)
});


//局部注冊
var app = new Vue({
 el: '#app',
 directive: {
 focus: {
 //指令選項(xiàng)
 }
 }
});

自定義指令的選項(xiàng)是由幾個(gè)鉤子函數(shù)組成的,每個(gè)都是可選的。

自定義指令的各個(gè)選項(xiàng)如下:

  • bind: 只調(diào)用一次,指令第一次綁定到元素時(shí)調(diào)用,用這個(gè)鉤子函數(shù)可以定義一個(gè)在綁定時(shí)執(zhí)行一次的初始化動作。
  • inserted: 被綁定元素插入父節(jié)點(diǎn)時(shí)調(diào)用(父節(jié)點(diǎn)存在即可調(diào)用,不必在于document中)。
  • update: 被綁定元素所在的模板更新時(shí)調(diào)用,而不論綁定值是否變化。通過比較更新前后的綁定值,可以忽略不必要的模板更新。
  • componentUpdated: 被綁定元素所在模板完成一次更新周期時(shí)調(diào)用。
  • unbind: 只調(diào)用一次,指令與元素解綁時(shí)調(diào)用。

可以根據(jù)需求在不同的鉤子函數(shù)內(nèi)完成邏輯代碼,例如上面的v-focus,我們希望在元素插入父節(jié)點(diǎn)時(shí)就調(diào)用,那用到的最好是inserted。

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <script src="https://unpkg.com/vue/dist/vue.js"></script>
 <title>自定義指令</title>
</head>
<body>
 <div id="app">
 <input type="text" v-focus>
 </div>
 <script>
 Vue.directive('focus',{
  inserted: function (el) {
  //聚焦元素
  el.focus();
  }
 });

 var app = new Vue({
  el: '#app'
 });
 </script>
</body>
</html>

每個(gè)鉤子函數(shù)都有幾個(gè)參數(shù)可用,具體如下:

  • el: 指令所綁定的元素,可以用來直接操作DOM
  • binding: 一個(gè)對象,包含以下屬性:

    name:指令名,不包括v-前綴
    valule:指令的綁定值,例如v-my-directive=“1 + 1”,value的值是2
    oldValue:指令綁定的前一個(gè)值,僅在update和componentUpdated鉤子中可用。無論值是否改變都可用
    expression:綁定值的字符串形式。例如v-my-directive=“1 + 1”,expression的值是”1 + 1“
    arg:傳給指令的參數(shù)。例如v-my-directive:foo,arg的值是foo
    modifiers:一個(gè)包含修飾符的對象。例如v-my-directive.foo.bar,修飾符對象modifiers的值是{ foo:true, bar:true}

  • vnode: Vue編譯生成的虛擬節(jié)點(diǎn)。
  • oldVnode: 上一個(gè)虛擬節(jié)點(diǎn)僅在update和componentUpdated鉤子中可用。

示例:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <script src="https://unpkg.com/vue/dist/vue.js"></script>
 <title>自定義指令</title>
</head>
<body>
 <div id="app">
 <div v-test:msg.a.b="message"></div>
 </div>
 <script>
 Vue.directive('test',{
  bind: function (el, binding, vnode) {
  var keys = [];
  for(var i in vnode){
   keys.push(i);
  }
  el.innerHTML = 
   'name:' + binding.name + '<br/>' +
   'value:' + binding.value + '<br/>' +
   'expression:' + binding.expression + '<br/>' +
   'argument:' + binding.arg + '<br/>' + 
   'modifiers:' + JSON.stringify(binding.modifiers) + '<br/>' + 
   'vnode keys' + keys.join(',');
  }
 });

 var app = new Vue({
  el: '#app',
  data: {
  message: 'some text'
  }
 });
 </script>
</body>
</html>

更多教程點(diǎn)擊《Vue.js前端組件學(xué)習(xí)教程》,歡迎大家學(xué)習(xí)閱讀。

關(guān)于vue.js組件的教程,請大家點(diǎn)擊專題vue.js組件學(xué)習(xí)教程進(jìn)行學(xué)習(xí)。

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

相關(guān)文章

  • 如何在vue3+ts項(xiàng)目中使用query和params傳參

    如何在vue3+ts項(xiàng)目中使用query和params傳參

    Vue3中的路由傳參有兩種方式:query和params,下面這篇文章主要給大家介紹了關(guān)于如何在vue3+ts項(xiàng)目中使用query和params傳參的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04
  • nuxt.js寫項(xiàng)目時(shí)增加錯(cuò)誤提示頁面操作

    nuxt.js寫項(xiàng)目時(shí)增加錯(cuò)誤提示頁面操作

    這篇文章主要介紹了nuxt.js寫項(xiàng)目時(shí)增加錯(cuò)誤提示頁面操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • Vue處理循環(huán)數(shù)據(jù)流程示例精講

    Vue處理循環(huán)數(shù)據(jù)流程示例精講

    這篇文章主要介紹了Vue處理循環(huán)數(shù)據(jù)流程,這個(gè)又是一個(gè)編程語言,?模版語法里面必不可少的一個(gè),?也是使用業(yè)務(wù)場景使用最多的一個(gè)環(huán)節(jié)。所以學(xué)會使用循環(huán)也是重中之重了
    2023-04-04
  • Flutter部件內(nèi)部狀態(tài)管理小結(jié)之實(shí)現(xiàn)Vue的v-model功能

    Flutter部件內(nèi)部狀態(tài)管理小結(jié)之實(shí)現(xiàn)Vue的v-model功能

    本文是 Flutter 部件內(nèi)部狀態(tài)管理的小結(jié),從部件的基礎(chǔ)開始,到部件的狀態(tài)管理,并且在過程中實(shí)現(xiàn)一個(gè)類似 Vue 的 v-model 的功能,感興趣的朋友跟隨小編一起看看吧
    2019-06-06
  • Vue3如何解決Element-plus不生效的問題

    Vue3如何解決Element-plus不生效的問題

    這篇文章主要介紹了Vue3如何解決Element-plus不生效的問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue滑動解鎖組件使用方法詳解

    vue滑動解鎖組件使用方法詳解

    這篇文章主要為大家詳細(xì)介紹了vue滑動解鎖組件的使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • vue組件props屬性監(jiān)聽不到值變化問題

    vue組件props屬性監(jiān)聽不到值變化問題

    這篇文章主要介紹了vue組件props屬性監(jiān)聽不到值變化問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue插槽slot的理解和使用方法

    vue插槽slot的理解和使用方法

    這篇文章主要給大家介紹了關(guān)于vue中插槽slot的理解和使用方法,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • Vue頁面跳轉(zhuǎn)動畫效果的實(shí)現(xiàn)方法

    Vue頁面跳轉(zhuǎn)動畫效果的實(shí)現(xiàn)方法

    百度了好久都沒辦法實(shí)現(xiàn)vue中一個(gè)頁面跳到另一個(gè)頁面,甚至到google上搜索也是沒辦法的,最終還是找了高人親自指導(dǎo),所以下面這篇文章主要給大家介紹了關(guān)于Vue頁面跳轉(zhuǎn)動畫效果的實(shí)現(xiàn)方法,需要的朋友可以參考下
    2018-09-09
  • Vue.js基礎(chǔ)知識小結(jié)

    Vue.js基礎(chǔ)知識小結(jié)

    本文主要介紹了Vue.js的相關(guān)知識。具有一定的參考價(jià)值,下面跟著小編一起來看下吧
    2017-01-01

最新評論