Vue.JS入門篇--事件監(jiān)聽

你可以使用 v-on 指令來綁定并監(jiān)聽 DOM 事件。綁定的內(nèi)容可以是一個當(dāng)前實例上的方法 (后面無需跟括號) 或一個內(nèi)聯(lián)表達(dá)式。如果提供的是一個方法,則原生的 DOM event 會被作為第一個參數(shù)傳入,同時這個 event 會帶有 targetVM 屬性,指向觸發(fā)該事件的相應(yīng)的 ViewModel:

<div id="demo">
    <a v-on="click: onClick">觸發(fā)一個方法函數(shù)</a>
    <a v-on="click: n++">觸發(fā)一個表達(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 時,targetVM 顯得很有用,因為 v-repeat 會創(chuàng)建大量子 ViewModel。但是,通過執(zhí)行表達(dá)式的方式,把代表當(dāng)前 ViewModel 數(shù)據(jù)對象的別名傳進去,會更方便直觀一些:

<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á)式中訪問原來的 DOM event,你可以傳遞一個 $event 參數(shù)進去。

key過濾器

當(dāng)監(jiān)聽鍵盤事件時,我們常常需要判斷常用的 key code。Vue.js 提供了一個特殊的只能用在 v-on 指令的過濾器:key。它接收一個表示 key code 的參數(shù)并完成判斷:

    <!-- 只有當(dāng) keyCode 等于 13 時才調(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)聽器

你可能會注意到整個事件監(jiān)聽的方式違背了 “separation of concern” 的傳統(tǒng)理念。不必?fù)?dān)心,因為所有的 Vue.js 事件處理方法和表達(dá)式都嚴(yán)格綁定在當(dāng)前視圖的 ViewModel 上,它不會導(dǎo)致任何維護困難。實際上,使用 v-on 還有更多好處:

它便于在 HTML 模板中輕松定位 JS 代碼里的對應(yīng)方法實現(xiàn)。
因為你無須在 JS 里手動綁定事件,你的 ViewModel 代碼可以是非常純粹的邏輯,和 DOM 完全解耦。這會更易于測試。
當(dāng)一個 ViewModel 被銷毀時,所有的事件監(jiān)聽都會被自動移除。你無須擔(dān)心如何自行清理它們。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 這篇筆記主要包含 Vue 2 不同于 Vue 1 或者特有的內(nèi)容,還有我對于 Vue 1.0 印象不深的內(nèi)容。關(guān)于...
    云之外閱讀 5,167評論 0 29
  • Vue 實例 屬性和方法 每個 Vue 實例都會代理其 data 對象里所有的屬性:var data = { a:...
    云之外閱讀 2,361評論 0 6
  • Vue筆記系列2、Vue.js漸進3、Vue.js進階 Vue.js的概述 如官網(wǎng)所說,Vue.js是一款輕量級的...
    其心閱讀 1,254評論 0 6
  • 我的童年是灰暗的, 所以我總想努力忘卻。 在博客和簡書上看了很多朋友的寫的童年往事,勾起了我的童年回憶。 ...
    81d1aa263da清風(fēng)閱讀 277評論 3 3
  • 豐姿偉岸立如松, 天下安危己任中。 巨柱擎空撐廣廈, 旌旗遍野搗黃龍。 刀光劍影終無懼, 血雨腥風(fēng)不動容。 一片丹...
    新平_4494閱讀 1,318評論 17 17

友情鏈接更多精彩內(nèi)容