国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

vue.js內部自定義指令與全局自定義指令的實現詳解(利用directive)

2019-11-19 16:06:45
字體:
來源:轉載
供稿:網友

前言

大家都知道在Vue中,我們平時數據驅動視圖時候,內部自帶的指令有時候解決不了一些需求,這時候,Vue給我們一個很好用的東東來實現自定義指令,這就是directive。下面話不多說了,來一起看看詳細的介紹:

directive

這個單詞是我們寫自定義指令的關鍵字哦

自定義指令為我們提供了幾個鉤子函數,這時候你一定好奇什么是鉤子函數,說簡單點,就是集中表現狀態

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

下面我們開始上代碼,讓我們更好的理解自定義指令怎么做

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Document</title> <script src="https://unpkg.com/vue/dist/vue.js"></script></head><body> <div id="app">  <div class="ab" v-css="{'color':'red','font-size':'30px'}"> hello </div> <input type="text" v-focus> </div> </body></html>

在html中,我們看到了兩個指令v-cssv-focus

我們自定義指令時候,一定前面要帶上v-

Vue.directive("css",{ //鉤子函數 ,el就是當前元素 inserted(el,binding){ //el綁定的元素本身 //binding就是css指令里面的的對象元素 let styleobj=binding.value,arr=[]; for(let key in styleobj){  arr.push(key+":"+styleobj[key])  } arr=arr.join(";"); el.style.cssText=arr; }, bind(el,binding) { //指令綁定在元素上時候執行,只執行一次 }}); new Vue({   el:'#app', data:{  show:true }, directives:{ focus:{  inserted(el,binding){  //el綁定的元素本身  //binding就是css指令里面的的對象元素  el.focus();  }  } } });

在js里面我們可以看到

Vue.directive("css",{})

我們在 new Vue外部定義了這樣一段代碼,這就是我們全局自定義指令的模板方式

  • css是自定義指令的名字
  • {}里面我們寫上鉤子函數就可以

我們所有的鉤子函數里面,基本都會有2個參數el,binding

  • el: 指令所綁定的元素,可以用來直接操作 DOM 。
  • binding 綁定元素本身的一個對象

從上面我們可以看到,binding里面保留綁定指令的name和value,這些很重要

局部自定義指令

directives:{ name:{ } }

區別在于,我們寫在new Vue里面,里面api操作和上面的全局自定義指令一樣

下面我們開始看代碼運行結果

我們可以看到樣式引用上去了

文本框也獲取了焦點

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 栾城县| 通河县| 双城市| 扬中市| 云阳县| 红安县| 合肥市| 花莲县| 抚远县| 南溪县| 叶城县| 印江| 灯塔市| 文水县| 湘西| 余庆县| 错那县| 那坡县| 安吉县| 都匀市| 涡阳县| 广饶县| 随州市| 永福县| 高台县| 拜城县| 娱乐| 垣曲县| 庄河市| 怀仁县| 新晃| 寿光市| 巍山| 铁岭市| 平和县| 许昌县| 昭平县| 株洲市| 金昌市| 边坝县| 宝鸡市|