Vue.JS入門(mén)教程之事件監(jiān)聽(tīng)
你可以使用 v-on 指令來(lái)綁定并監(jiān)聽(tīng) DOM 事件。綁定的內(nèi)容可以是一個(gè)當(dāng)前實(shí)例上的方法 (后面無(wú)需跟括號(hào)) 或一個(gè)內(nèi)聯(lián)表達(dá)式。如果提供的是一個(gè)方法,則原生的 DOM event 會(huì)被作為第一個(gè)參數(shù)傳入,同時(shí)這個(gè) event 會(huì)帶有 targetVM 屬性,指向觸發(fā)該事件的相應(yīng)的 ViewModel:
<div id="demo"> <a v-on="click: onClick">觸發(fā)一個(gè)方法函數(shù)</a> <a v-on="click: n++">觸發(fā)一個(gè)表達(dá)式</a> </div>
new Vue({ el: '#demo', data: { n: 0 }, methods: { onClick: function (e) { console.log(e.targetVM.n); console.log(e.target.tagName);// "A" console.log(e.targetVM === this);// true } } });
執(zhí)行表達(dá)式
當(dāng)在 v-repeat 里使用 v-on 時(shí),targetVM 顯得很有用,因?yàn)?v-repeat 會(huì)創(chuàng)建大量子 ViewModel。但是,通過(guò)執(zhí)行表達(dá)式的方式,把代表當(dāng)前 ViewModel 數(shù)據(jù)對(duì)象的別名傳進(jìn)去,會(huì)更方便直觀一些:
<ul id="list"> <li v-repeat="item in items" v-on="click: toggle(item)"> {{item.text}} </li> <button v-on="click: submit('hello!', $event)">Submit</button> </ul>
new Vue({ el: '#list', data: { items: [ { text: 'one', done: true }, { text: 'two', done: false } ] }, methods: { toggle: function (item) { console.info(item.done); item.done = !item.done; console.info(item.done); }, submit: function (msg, e) { e.stopPropagation(); console.info(msg + ' submit is called!'); } } })
當(dāng)你想要在表達(dá)式中訪問(wèn)原來(lái)的 DOM event,你可以傳遞一個(gè) $event 參數(shù)進(jìn)去。
key過(guò)濾器
當(dāng)監(jiān)聽(tīng)鍵盤(pán)事件時(shí),我們常常需要判斷常用的 key code。Vue.js 提供了一個(gè)特殊的只能用在 v-on 指令的過(guò)濾器:key。它接收一個(gè)表示 key code 的參數(shù)并完成判斷:
<!-- 只有當(dāng) keyCode 等于 13 時(shí)才調(diào)用方法 --> <input v-on="keyup:mySubmit | key 13">
系統(tǒng)有很多預(yù)設(shè)值可以使用,例如:
<!-- 效果同上 --> <input v-on="keyup:submit | key 'enter'">
預(yù)設(shè)值為:enter tab delete esc up down left right space
為什么在HTML中使用監(jiān)聽(tīng)器
你可能會(huì)注意到整個(gè)事件監(jiān)聽(tīng)的方式違背了 “separation of concern” 的傳統(tǒng)理念。不必?fù)?dān)心,因?yàn)樗械?Vue.js 事件處理方法和表達(dá)式都嚴(yán)格綁定在當(dāng)前視圖的 ViewModel 上,它不會(huì)導(dǎo)致任何維護(hù)困難。實(shí)際上,使用 v-on 還有更多好處:
它便于在 HTML 模板中輕松定位 JS 代碼里的對(duì)應(yīng)方法實(shí)現(xiàn)。
因?yàn)槟銦o(wú)須在 JS 里手動(dòng)綁定事件,你的 ViewModel 代碼可以是非常純粹的邏輯,和 DOM 完全解耦。這會(huì)更易于測(cè)試。
當(dāng)一個(gè) ViewModel 被銷(xiāo)毀時(shí),所有的事件監(jiān)聽(tīng)都會(huì)被自動(dòng)移除。你無(wú)須擔(dān)心如何自行清理它們。
本文已被整理到了《Vue.js前端組件學(xué)習(xí)教程》,歡迎大家學(xué)習(xí)閱讀。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue項(xiàng)目中實(shí)現(xiàn)帶參跳轉(zhuǎn)功能
最近做了一個(gè)手機(jī)端系統(tǒng),其中遇到了父頁(yè)面需要攜帶參數(shù)跳轉(zhuǎn)至子頁(yè)面的問(wèn)題,現(xiàn)已解決,下面分享一下實(shí)現(xiàn)過(guò)程,感興趣的朋友一起看看吧2021-04-04Vue中消息橫向滾動(dòng)時(shí)setInterval清不掉的問(wèn)題及解決方法
最近在做項(xiàng)目時(shí),需要進(jìn)行兩個(gè)組件聯(lián)動(dòng),一個(gè)輪詢(xún)獲取到消息,然后將其傳遞給另外一個(gè)組件進(jìn)行橫向滾動(dòng)展示,結(jié)果滾動(dòng)的速度越來(lái)越快。接下來(lái)通過(guò)本文給大家分享Vue中消息橫向滾動(dòng)時(shí)setInterval清不掉的問(wèn)題及解決方法,感興趣的朋友一起看看吧2019-08-08vue-router之實(shí)現(xiàn)導(dǎo)航切換過(guò)渡動(dòng)畫(huà)效果
今天小編就為大家分享一篇vue-router之實(shí)現(xiàn)導(dǎo)航切換過(guò)渡動(dòng)畫(huà)效果,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10vue父子組件傳值以及單向數(shù)據(jù)流問(wèn)題詳解
大家應(yīng)該都知道父組件可以向子組件通過(guò)屬性形式傳遞參數(shù),傳遞的參數(shù)也可以隨時(shí)隨意修改;但子組件不能修改父組件傳遞過(guò)來(lái)的參數(shù),所以下面這篇文章主要給大家介紹了關(guān)于vue父子組件傳值以及單向數(shù)據(jù)流問(wèn)題的相關(guān)資料,需要的朋友可以參考下2021-09-09vue+springboot實(shí)現(xiàn)項(xiàng)目的CORS跨域請(qǐng)求
這篇文章主要介紹了vue+springboot實(shí)現(xiàn)項(xiàng)目的CORS跨域請(qǐng)求,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09