Vue自定義鍵盤信息,自定義指令

例:自定義鍵盤信息
 Vue.directive('on').keyCodes.ctrl=17;
        Vue.directive('on').keyCodes.myenter=13;
        window.onload = function(){
            var vm = new Vue({
                el:'#box',
                data:{},
                methods:{
                    show:function(){
                        alert(111);
                    }
                }
            });
        }

<input type="text" @keydown.ctrl="show">
<hr>
<input type="text" @keydown.myenter="show | debounce 2000">

自定義指令

1卤妒、Vue.directive(id,definition)注冊(cè)一個(gè)全局自定義指令甥绿,接收兩個(gè)參數(shù)叠必,指令I(lǐng)D以及定義對(duì)象

2、鉤子函數(shù):將作用域與DOM進(jìn)行鏈接妹窖,鏈接函數(shù)用來(lái)創(chuàng)建可以操作DOM的指令

bind - 只調(diào)用一次纬朝,在指令第一次綁定到元素上時(shí)候調(diào)用
update - 在bind之后立即以初始值為參數(shù)第一次調(diào)用,之后綁定值變化的時(shí)候骄呼,參數(shù)為新值與舊值
unbind - 只調(diào)用一次共苛,在指令從元素上解綁的時(shí)候調(diào)用

Vue.directive('my-directive',{
    bind : function(){
        //準(zhǔn)備工作
        //例如,添加事件處理器或只需要運(yùn)行一次的高耗任務(wù)
    },
    update : function(){
        //值更新時(shí)的工作
        //也會(huì)以初始值為參數(shù)調(diào)用一次
    },
    unzind : function(){
        //清理工作
        //例如蜓萄,刪除bind()添加的事件監(jiān)聽器
    }
})
//調(diào)用
<div v-my-directive="someValue"></div>
//只需要update函數(shù)隅茎,可以傳一個(gè)函數(shù)替代定義對(duì)象
Vue.directive('my-directive',function(value){})
<!-- 如果指令需要多個(gè)值,可以傳入一個(gè)js對(duì)象 -->
<!-- 指令可以使用合法的js表達(dá)式 -->
<body id="example">
    <div id="demo" v-demo="{color : 'white',text : 'hello!'}"></div>
</body>
<script>
    Vue.directive('demo',function(value){
        console.info(value.color); //white
        console.info(value.text) // hello!
    })
    var demo = new Vue({
        el : '#demo'
    })
</script>

當(dāng)指令使用字面修飾符嫉沽,值將按普通字符串處理并傳遞給update方法辟犀,update方法只調(diào)用一次,因?yàn)槠胀ㄗ址荒苡绊憯?shù)據(jù)變化

<body id="example">
    <div id="demo" v-demo.literal="foo bar baz"></div>
</body>
<script>
    Vue.directive('demo',function(value){
        console.info(value); //foo bar baz
    })
    var demo = new Vue({
        el : '#demo'
    })
</script>

3绸硕、以屬性的形式使用自定義屬性

<body id="demo">
    <my-directive class="hello" name="hi"></my-directive>
</body>
<script type="text/javascript">
    Vue.elementDirective('my-directive',{
        //api同普通指令一致
        bind : function(){
            console.info(this.el.className);
            console.info(this.el.getAttribute('name'))
        }
    })

    var demo = new Vue({
        el : '#demo'
    })
</script>

4堂竟、自定義屬性用在對(duì)象上,對(duì)象內(nèi)部屬性變化的時(shí)候觸發(fā)update玻佩,在指令定義對(duì)象中指定deep:true

<body id="demo">
    <div v-my-directive="a"></div>
    <button @click="change">change</button>{{a,b,c}}
</body>
<script>
    Vue.directive('my-directive',function(){
        deep : true,

        update : function(obj){
            //當(dāng)obj的嵌套屬性變化時(shí)候調(diào)用
            console.info(obj.b.c);
        }
    })
    var demoVM = new Vue({
        el : '#demo',

        data : {
            a : {b : {c : 2}}
        },

        method : {
            change : function(){
                demoVM.a.b.c = 4;
            }
        }
    })
</script>

5出嘹、acceptStatement讓自定義指令接受內(nèi)聯(lián)語(yǔ)句

<body id="demo">
    <div v-my-directive="a++"></div>
    {{a}}
</body>
<script>
    Vue.directive('my-directive',function(){
        acceptStatement : true,

        update : function(fn){
            //當(dāng)obj的嵌套屬性變化時(shí)候調(diào)用
            console.info(fn.toString())
            fu();
        }
    })
    var demoVM = new Vue({
        el : '#demo',

        data : {
            a : 5
        }
    })
</script>

6、v-on綁定多個(gè)事件時(shí)咬崔,要是是不同的事件類型税稼,例如點(diǎn)擊,focus垮斯,change郎仆,會(huì)按照業(yè)務(wù)需求進(jìn)行

選擇,要是綁定了2個(gè)甚至多個(gè)click事件兜蠕,那么v-on只會(huì)綁定第一個(gè)click事件

附自定義拖拽指令
   <body>
    <div id="box">
        <div v-drag :style="{width:'100px', height:'100px', background:'blue', position:'absolute', right:0, top:0}"></div>
        <div v-drag :style="{width:'100px', height:'100px', background:'red', position:'absolute', left:0, top:0}"></div>
    </div>

</body>
    <script>
        window.onload=function(){
              Vue.directive('drag',{
                inserted: function (el) {
                    var oDiv=el;
                    oDiv.onmousedown=function(ev){
                        var disX=ev.clientX-oDiv.offsetLeft;
                        var disY=ev.clientY-oDiv.offsetTop;
                        document.onmousemove=function(ev){
                            var l=ev.clientX-disX;
                            var t=ev.clientY-disY;
                            oDiv.style.left=l+'px';
                            oDiv.style.top=t+'px';
                        };
                        document.onmouseup=function(){
                            document.onmousemove=null;
                            document.onmouseup=null;
                        };
                    };
                }
            });
            var vm=new Vue({
                el:'#box',
                data:{
                    msg:''
                }
            });
        };

    </script>

字面指令

如果在創(chuàng)建自定義指令的時(shí)候傳入 isLiteral: true 扰肌,那么特性值就會(huì)被看成直接字符串,并被賦值給該指令的 expression牺氨。字面指令不會(huì)試圖建立數(shù)據(jù)監(jiān)視狡耻。
例子:

<div v-literal-dir="foo"></div>
Vue.directive('literal-dir', {
  isLiteral: true,
  bind: function () {
    console.log(this.expression) // 'foo'
  }
})

動(dòng)態(tài)字面指令

然而墩剖,在字面指令含有 Mustache 標(biāo)簽的情形下猴凹,指令的行為如下:

指令實(shí)例會(huì)有一個(gè)屬性,this._isDynamicLiteral被設(shè)為true岭皂;
如果沒(méi)有提供update函數(shù)郊霎,Mustache 表達(dá)式只會(huì)被求值一次,并將該值賦給this.expression爷绘。不會(huì)對(duì)表達(dá)式進(jìn)行數(shù)據(jù)監(jiān)視书劝。
如果提供了update函數(shù)进倍,指令將會(huì)為表達(dá)式建立一個(gè)數(shù)據(jù)監(jiān)視,并且在計(jì)算結(jié)果變化的時(shí)候調(diào)用update购对。

雙向指令

如果你的指令想向 Vue 實(shí)例寫回?cái)?shù)據(jù)猾昆,你需要傳入 twoWay: true 。該選項(xiàng)允許在指令中使用
this.set(value)骡苞。

Vue.directive('example', {
  twoWay: true,
  bind: function () {
    this.handler = function () {
      // 把數(shù)據(jù)寫回 vm
      // 如果指令這樣綁定 v-example="a.b.c",
      // 這里將會(huì)給 `vm.a.b.c` 賦值
      this.set(this.el.value)
    }.bind(this)
    this.el.addEventListener('input', this.handler)
  },
  unbind: function () {
    this.el.removeEventListener('input', this.handler)
  }
})

元素指令

有時(shí)候垂蜗,我們可能想要我們的指令可以以自定義元素的形式被使用,而不是作為一個(gè)特性。這與 Angular 的 E 類指令的概念非常相似。元素指令可以看做是一個(gè)輕量的自定義組件(后面會(huì)講到)直颅。你可以像下面這樣注冊(cè)一個(gè)自定義的元素指令:

Vue.elementDirective('my-directive', {
  // 和普通指令的 API 一致
  bind: function () {
    // 對(duì) this.el 進(jìn)行操作...
  }
})
使用時(shí)我們不再用這樣的寫法:

<div v-my-directive></div>
而是寫成:

<my-directive></my-directive>

元素指令不能接受參數(shù)或表達(dá)式邑茄,但是它可以讀取元素的特性,來(lái)決定它的行為打颤。與通常的指令有個(gè)很大的不同,元素指令是終結(jié)性的,這意味著档悠,一旦 Vue 遇到一個(gè)元素指令,它將跳過(guò)對(duì)該元素和其子元素的編譯 - 即只有該元素指令本身可以操作該元素及其子元素望浩。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末站粟,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子曾雕,更是在濱河造成了極大的恐慌奴烙,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,490評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件剖张,死亡現(xiàn)場(chǎng)離奇詭異切诀,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)搔弄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門幅虑,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人顾犹,你說(shuō)我怎么就攤上這事倒庵。” “怎么了炫刷?”我有些...
    開封第一講書人閱讀 165,830評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵擎宝,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我浑玛,道長(zhǎng)绍申,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,957評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮极阅,結(jié)果婚禮上胃碾,老公的妹妹穿的比我還像新娘。我一直安慰自己筋搏,他們只是感情好仆百,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評(píng)論 6 393
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著奔脐,像睡著了一般儒旬。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上帖族,一...
    開封第一講書人閱讀 51,754評(píng)論 1 307
  • 那天栈源,我揣著相機(jī)與錄音,去河邊找鬼竖般。 笑死甚垦,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的涣雕。 我是一名探鬼主播艰亮,決...
    沈念sama閱讀 40,464評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼挣郭!你這毒婦竟也來(lái)了迄埃?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤兑障,失蹤者是張志新(化名)和其女友劉穎侄非,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體流译,經(jīng)...
    沈念sama閱讀 45,847評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡逞怨,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評(píng)論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了福澡。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片叠赦。...
    茶點(diǎn)故事閱讀 40,137評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖革砸,靈堂內(nèi)的尸體忽然破棺而出除秀,到底是詐尸還是另有隱情,我是刑警寧澤算利,帶...
    沈念sama閱讀 35,819評(píng)論 5 346
  • 正文 年R本政府宣布册踩,位于F島的核電站,受9級(jí)特大地震影響笔时,放射性物質(zhì)發(fā)生泄漏棍好。R本人自食惡果不足惜仗岸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評(píng)論 3 331
  • 文/蒙蒙 一允耿、第九天 我趴在偏房一處隱蔽的房頂上張望借笙。 院中可真熱鬧,春花似錦较锡、人聲如沸业稼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)低散。三九已至,卻和暖如春骡楼,著一層夾襖步出監(jiān)牢的瞬間熔号,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工鸟整, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留引镊,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,409評(píng)論 3 373
  • 正文 我出身青樓篮条,卻偏偏與公主長(zhǎng)得像弟头,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子涉茧,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評(píng)論 2 355

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

  • 這篇筆記主要包含 Vue 2 不同于 Vue 1 或者特有的內(nèi)容赴恨,還有我對(duì)于 Vue 1.0 印象不深的內(nèi)容。關(guān)于...
    云之外閱讀 5,050評(píng)論 0 29
  • Vue 實(shí)例 屬性和方法 每個(gè) Vue 實(shí)例都會(huì)代理其 data 對(duì)象里所有的屬性:var data = { a:...
    云之外閱讀 2,214評(píng)論 0 6
  • 1.安裝 可以簡(jiǎn)單地在頁(yè)面引入Vue.js作為獨(dú)立版本伴栓,Vue即被注冊(cè)為全局變量伦连,可以在頁(yè)面使用了。 如果希望搭建...
    Awey閱讀 11,029評(píng)論 4 129
  • 基礎(chǔ) Vue.js 允許你注冊(cè)自定義指令钳垮,實(shí)質(zhì)上是讓你教 Vue 一些新技巧:怎樣將數(shù)據(jù)的變化映射到 DOM 的行...
    hutou閱讀 14,800評(píng)論 0 11
  • 麥琪土司家的二兒子除师,生命從十三歲開始。 從擁有一個(gè)叫卓瑪?shù)氖膛D―一個(gè)年輕的扔枫、馬夫的女兒開始汛聚。 地主家...
    葉弗御閱讀 1,051評(píng)論 0 0