大白話Vue2.x-directive

除了默認(rèn)設(shè)置的核心指令( v-model 和 v-show ),Vue 也允許注冊(cè)自定義指令谊路。注意赊锚,在 Vue2.0 里面成箫,代碼復(fù)用的主要形式和抽象是組件——然而格郁,有的情況下,你仍然需要對(duì)純 DOM 元素進(jìn)行底層操作,這時(shí)候就會(huì)用到自定義指令腹殿。

官方建議directive是對(duì)純 DOM 元素進(jìn)行底層操作使用独悴,一般情況下還是建議使用組件的復(fù)用。

directive的意義

自定義指令是用來(lái)操作DOM的锣尉。

盡管數(shù)據(jù)驅(qū)動(dòng)是Vue的核心之一刻炒,但是在實(shí)際情況下,并不是所有的情況都可以用數(shù)據(jù)來(lái)驅(qū)動(dòng)視圖自沧,我們不可避免的會(huì)在有些情況下有操作DOM的需求坟奥,所以directive也就出現(xiàn)了。自定義指令就是一種有效的補(bǔ)充和擴(kuò)展拇厢,不僅可用于定義任何的DOM操作爱谁,并且是可復(fù)用的。

官方栗子

code

// 注冊(cè)一個(gè)全局自定義指令 v-focus
Vue.directive('focus', {
  // 當(dāng)綁定元素插入到 DOM 中孝偎。
  inserted: function (el) {
    // 聚焦元素
    el.focus()
  }
})

//局部指令
directive: {
  focus(el){
    el.focus()
  }
}

use

<input v-focus>
//input標(biāo)簽自動(dòng)獲得標(biāo)簽

是不是感覺很簡(jiǎn)單管行?相信自己,其實(shí)vue大法真心不難邪媳,難得是如何應(yīng)用捐顷。下面先來(lái)簡(jiǎn)單看看的鉤子函數(shù)。

鉤子函數(shù)

  • bind:在該元素綁定指令時(shí)調(diào)用且僅調(diào)用一次雨效,用于初始化
  • inserted:元素插入父節(jié)點(diǎn)時(shí)調(diào)用(可能仍在虛擬Dom中)
  • update:模板更新時(shí)調(diào)用
  • componentUpdated: 被綁定元素所在模板完成一次更新周期時(shí)調(diào)用迅涮。
  • unbind: 只調(diào)用一次, 指令與元素解綁時(shí)調(diào)用徽龟。

鉤子參數(shù)

  • el: 指令所綁定的元素叮姑,可以用來(lái)直接操作 DOM 。
  • binding: 一個(gè)對(duì)象据悔,包含以下屬性:
    • name: 指令名传透,不包括 v- 前綴。
    • value: 指令的綁定值
    • oldValue: 指令綁定的前一個(gè)值极颓,僅在 update 和 componentUpdated 鉤子中可用朱盐。無(wú)論值是否改變都可用。
    • expression: 綁定值的字符串形式菠隆。 例如 v-my-directive="1 + 1" 兵琳, expression 的值是 "1 + 1"。
    • arg: 傳給指令的參數(shù)骇径。例如 v-my-directive:foo躯肌, arg 的值是 "foo"。
    • modifiers: 一個(gè)包含修飾符的對(duì)象破衔。 例如: v-my-directive.foo.bar, 修飾符對(duì)象 modifiers 的值是 { foo: true, bar: true }清女。
  • vnode: Vue 編譯生成的虛擬節(jié)點(diǎn)。
  • oldVnode: 上一個(gè)虛擬節(jié)點(diǎn)晰筛,僅在 update 和 componentUpdated 鉤子中可用嫡丙。

實(shí)際應(yīng)用

directive的語(yǔ)法就這么簡(jiǎn)單忠售,在合適的鉤子中做應(yīng)該做的事就可以了。下面會(huì)列出兩個(gè)使用指令的栗子

集成第三方插件

用了一段時(shí)間的vue迄沫,其實(shí)我都沒有留意directive具體使用稻扬,一般來(lái)言真的很少使用到。直到有一次需要集成第三方插件到Vue時(shí)才發(fā)現(xiàn)羊瘩,原來(lái)directive是集成第三方插件最合適也是最簡(jiǎn)單的方式泰佳。凡是關(guān)于第三方的集成,都可以嘗試使用directive

import Vue from 'vue'
import hljs from 'highlight.js'
import 'highlight.js/styles/monokai-sublime.css'

Vue.directive('highlight', {
  bind(el){
    hljs.highlightBlock(el);
  },
})

use

<pre>
  <code v-highlight>
     //code here
  </code>
</pre>

如上尘吗,我注冊(cè)了一個(gè)全局的指令 highlight逝她。 指令的作用就是高亮代碼,當(dāng)元素帶上'v-highlight'時(shí)睬捶,hljs就會(huì)去初始化該Dom黔宛。

當(dāng)然我這是可以使用組件來(lái)實(shí)現(xiàn)這個(gè)功能,但絕對(duì)沒有指令那么方便快捷擒贸,下面是一個(gè)簡(jiǎn)略的組件臀晃,可以看出,不僅定義和使用都比指令來(lái)的復(fù)雜介劫。

<template>
    <pre>
        <code ref="code">
          <slot name="code"></slot>
        </code>
    </pre>
</template>
<script>
    import hljs from 'highlight.js'
    import 'highlight.js/styles/monokai-sublime.css'
    export default {
        mounted(){
          hljs.highlightBlock(this.$refs.code);
        }
    }
</script>

指令驗(yàn)證

如果需要一個(gè)可以復(fù)用的驗(yàn)證徽惋,我們也可以使指令來(lái)完成,下面來(lái)看一個(gè)簡(jiǎn)單的栗子:

Vue.directive('checkName', {
  //監(jiān)控?cái)?shù)據(jù)變化  
  update(el, binding){
      let regex = /^[a-zA-z]{6,10}$/g;
      //=value === oldValue, 避免重復(fù)更新
      if(binding.value !== binding.oldValue){
          el.style.border = regex.test(binding.value) ? '' : '1px solid red';
      }
  }
})

user

<input v-model='value1' v-checkName='value1'></input>
<input v-model='value2' v-checkName='value2'></input>
<input v-model='value3' v-checkName='value3'></input>
<input v-model='value4' v-checkName='value4'></input>

//當(dāng)value的值不是6-10的字母的時(shí)座韵,input的boder變?yōu)榧t色;

result


result

結(jié)果很明顯险绘,不符合規(guī)則的數(shù)據(jù),input的邊框變紅了誉碴。

End

這里只是抄寫下官方的文檔宦棺,舉兩個(gè)栗子,就是那么簡(jiǎn)單黔帕,任性 ( ̄~ ̄) 代咸!其實(shí)主要想說(shuō)明白的一件事就是明確dirctive的意義:指令是用來(lái)操作DOM的,希望能起到拋磚引玉的作用吧蹬屹。

參考

VUE-自定義指令

原文鏈接-瘋子的博客

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末侣背,一起剝皮案震驚了整個(gè)濱河市白华,隨后出現(xiàn)的幾起案子慨默,更是在濱河造成了極大的恐慌,老刑警劉巖弧腥,帶你破解...
    沈念sama閱讀 216,744評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件厦取,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡管搪,警方通過(guò)查閱死者的電腦和手機(jī)虾攻,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,505評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門铡买,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人霎箍,你說(shuō)我怎么就攤上這事奇钞。” “怎么了漂坏?”我有些...
    開封第一講書人閱讀 163,105評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵景埃,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我顶别,道長(zhǎng)谷徙,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,242評(píng)論 1 292
  • 正文 為了忘掉前任驯绎,我火速辦了婚禮完慧,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘剩失。我一直安慰自己屈尼,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,269評(píng)論 6 389
  • 文/花漫 我一把揭開白布拴孤。 她就那樣靜靜地躺著鸿染,像睡著了一般。 火紅的嫁衣襯著肌膚如雪乞巧。 梳的紋絲不亂的頭發(fā)上涨椒,一...
    開封第一講書人閱讀 51,215評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音绽媒,去河邊找鬼蚕冬。 笑死,一個(gè)胖子當(dāng)著我的面吹牛是辕,可吹牛的內(nèi)容都是我干的囤热。 我是一名探鬼主播,決...
    沈念sama閱讀 40,096評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼获三,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼旁蔼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起疙教,我...
    開封第一講書人閱讀 38,939評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤棺聊,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后贞谓,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體限佩,經(jīng)...
    沈念sama閱讀 45,354評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,573評(píng)論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了祟同。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片作喘。...
    茶點(diǎn)故事閱讀 39,745評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖晕城,靈堂內(nèi)的尸體忽然破棺而出泞坦,到底是詐尸還是另有隱情,我是刑警寧澤砖顷,帶...
    沈念sama閱讀 35,448評(píng)論 5 344
  • 正文 年R本政府宣布暇矫,位于F島的核電站,受9級(jí)特大地震影響择吊,放射性物質(zhì)發(fā)生泄漏李根。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,048評(píng)論 3 327
  • 文/蒙蒙 一几睛、第九天 我趴在偏房一處隱蔽的房頂上張望房轿。 院中可真熱鬧,春花似錦所森、人聲如沸囱持。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,683評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)纷妆。三九已至,卻和暖如春晴弃,著一層夾襖步出監(jiān)牢的瞬間掩幢,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,838評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工上鞠, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留际邻,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,776評(píng)論 2 369
  • 正文 我出身青樓芍阎,卻偏偏與公主長(zhǎng)得像世曾,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子谴咸,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,652評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • Vue 實(shí)例 屬性和方法 每個(gè) Vue 實(shí)例都會(huì)代理其 data 對(duì)象里所有的屬性:var data = { a:...
    云之外閱讀 2,207評(píng)論 0 6
  • 這篇筆記主要包含 Vue 2 不同于 Vue 1 或者特有的內(nèi)容轮听,還有我對(duì)于 Vue 1.0 印象不深的內(nèi)容。關(guān)于...
    云之外閱讀 5,048評(píng)論 0 29
  • 1.安裝 可以簡(jiǎn)單地在頁(yè)面引入Vue.js作為獨(dú)立版本岭佳,Vue即被注冊(cè)為全局變量血巍,可以在頁(yè)面使用了。 如果希望搭建...
    Awey閱讀 11,015評(píng)論 4 129
  • 小的時(shí)候鄰居家辦喜事驼唱,看別人喝酒藻茂,覺得好奇,拿根筷子在大人酒杯里蘸一下玫恳,放在嘴里舔一下辨赐,那個(gè)怪味兒彌漫上來(lái),眼淚差...
    麥子2008閱讀 451評(píng)論 17 9
  • 這兩天整理方案的空當(dāng)把《春嬌救志明》看完了(還是建議大家去電影院支持正版)京办,看著杭州灣大橋掀序,心生感慨,愛情真好啊惭婿。...
    惠夕安閱讀 260評(píng)論 0 0