Vue 2.0 自定義指令

自定義指令

自定義指令基本就是用來操作DOM的,雖然官方推薦數(shù)據(jù)驅(qū)動視圖,有時候還是需要自定義指令來操作DOM,指令可復(fù)用.

自定義指令郎楼,可以全局和局部注冊裸影,

1. 全局自定義指令

全局自定義指令需要使用 全局 API Vue.directive( id, [definition] ) definition 可以是 函數(shù)和 json對象

自定義指令有5個鉤子函數(shù)
Vue.directive('hello',{
    bind(el,binding){
        alert('只調(diào)用一次,指令第一次綁定到元素時調(diào)用,可執(zhí)行初始化操作')
    },
    inserted(){
        alert('被綁定元素插入DOM時調(diào)用')
    },
    update(){
        alert('被綁定元素所在模板更新時調(diào)用')
    },
    componentUpdated(){
        alert('被綁定元素所在模板更新完成后調(diào)用')
    },
    unbind(){
        alert('只調(diào)用一次指令與元素解綁時調(diào)用')
    }
})
鉤子函數(shù)參數(shù)
  • el:指令所綁定的元素随闽,可以用來直接操作 DOM 质况。
  • binding:一個對象包含以下屬性
    • name:指令名斧账,不包括 v- 前綴
    • rawName:指令名 包含 v-
    • value:指令綁定值 比如v-hello='name' 綁定值就是vue data對象里 的name值
    • expression:指令綁定值的字符串形式
    • arg:傳給指令的參數(shù) v-hello:aaa='name' aaa就是參數(shù) aaa是自己定義的
    • modifiers:一個包含修飾符的對象例如:v-my-directive.foo.bar 中,修飾符對象為 { foo: true, bar: true }

注意: val 指令綁定值 只能是 vue實例下 data對象的數(shù)據(jù) arg 參數(shù)是自己隨便定義的

查看鉤子函數(shù)和參數(shù)演示

自定義指令語法簡寫

以上自定義指令語法 有些繁瑣 vue.directive() 允許你傳入一個函數(shù) 相當(dāng)于 bind 和 update

// 注冊 (指令函數(shù))
Vue.directive('my-directive', function () {
  // 這里將會被 `bind` 和 `update` 調(diào)用
})

實例

  1. 使用自定義指令做一個輸入框自定聚焦
<div id="app">
  <input v-focus type="" name="" id="" value="" />
</div>
Vue.directive('focus',{
//被綁定元素插入DOM時觸發(fā)
  inserted:function(el){
    el.focus()
  }
})

new Vue({
  el:'#app',
})

查看實例演示

  1. 使用自定義指令做元素拖拽
<div id="app">
    <div class="box bgred lt0" v-drag></div>
    <div class="box bgblue rt0" v-drag></div>
</div>
Vue.directive('drag',function(el){
    el.onmousedown=function(e){
        var w = e.clientX - el.offsetLeft
        var h = e.clientY - el.offsetTop
        document.onmousemove=function(e){
            var x = e.clientX-w;
            var y = e.clientY-h;
            el.style.left=x+"px"
            el.style.top=y+'px'
        };
        document.onmouseup=function(){
            document.onmousemove=null;
            document.onmouseup =null
        }
    }
})
var vm = new Vue({
    el:'#app',
})

拖拽指令演示

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末冠桃,一起剝皮案震驚了整個濱河市命贴,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌食听,老刑警劉巖胸蛛,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異樱报,居然都是意外死亡葬项,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進(jìn)店門迹蛤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來民珍,“玉大人,你說我怎么就攤上這事盗飒∪铝浚” “怎么了?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵逆趣,是天一觀的道長蝶溶。 經(jīng)常有香客問我,道長汗贫,這世上最難降的妖魔是什么身坐? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮落包,結(jié)果婚禮上部蛇,老公的妹妹穿的比我還像新娘。我一直安慰自己咐蝇,他們只是感情好涯鲁,可當(dāng)我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般抹腿。 火紅的嫁衣襯著肌膚如雪岛请。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天警绩,我揣著相機與錄音崇败,去河邊找鬼。 笑死肩祥,一個胖子當(dāng)著我的面吹牛后室,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播混狠,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼岸霹,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了将饺?” 一聲冷哼從身側(cè)響起贡避,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎予弧,沒想到半個月后刮吧,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡桌肴,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年皇筛,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片坠七。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡水醋,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出彪置,到底是詐尸還是另有隱情拄踪,我是刑警寧澤,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布拳魁,位于F島的核電站惶桐,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏潘懊。R本人自食惡果不足惜姚糊,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望授舟。 院中可真熱鬧救恨,春花似錦、人聲如沸释树。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至秸仙,卻和暖如春嘴拢,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背寂纪。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工席吴, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人弊攘。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓抢腐,卻偏偏與公主長得像,于是被迫代替她去往敵國和親襟交。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,828評論 2 345

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