国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Vue.JS入門教程之事件監聽

2019-11-19 18:44:31
字體:
來源:轉載
供稿:網友

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

<div id="demo"> <a v-on="click: onClick">觸發一個方法函數</a> <a v-on="click: n++">觸發一個表達式</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  } } });

執行表達式

當在 v-repeat 里使用 v-on 時,targetVM 顯得很有用,因為 v-repeat 會創建大量子 ViewModel。但是,通過執行表達式的方式,把代表當前 ViewModel 數據對象的別名傳進去,會更方便直觀一些:

<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!');  } } })

當你想要在表達式中訪問原來的 DOM event,你可以傳遞一個 $event 參數進去。

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

 <!-- 只有當 keyCode 等于 13 時才調用方法 --> <input v-on="keyup:mySubmit | key 13">

系統有很多預設值可以使用,例如:

<!-- 效果同上 --><input v-on="keyup:submit | key 'enter'">

預設值為:enter tab delete esc up down left right space

為什么在HTML中使用監聽器
你可能會注意到整個事件監聽的方式違背了 “separation of concern” 的傳統理念。不必擔心,因為所有的 Vue.js 事件處理方法和表達式都嚴格綁定在當前視圖的 ViewModel 上,它不會導致任何維護困難。實際上,使用 v-on 還有更多好處:

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

本文已被整理到了《Vue.js前端組件學習教程》,歡迎大家學習閱讀。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 得荣县| 漳州市| 红桥区| 舞钢市| 将乐县| 衡水市| 汉中市| 利辛县| 德江县| 普陀区| 云和县| 长岛县| 大同市| 寻甸| 元氏县| 玉林市| 镇远县| 孟连| 金沙县| 平阳县| 龙泉市| 武城县| 赤城县| 宜宾县| 吉木萨尔县| 灵石县| 庆云县| 灌南县| 安岳县| 兰州市| 西乌| 河东区| 湾仔区| 浮梁县| 桦川县| 克东县| 灌阳县| 塔城市| 威宁| 镇沅| 临西县|