欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue.JS入門教程之事件監(jiān)聽

 更新時間:2016年12月01日 10:38:30   作者:hutou  
這篇文章主要為大家詳細(xì)介紹了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ù)對象的別名傳進(jìn)去,會更方便直觀一些:

<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ù)進(jìn)去。

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)致任何維護(hù)困難。實際上,使用 v-on 還有更多好處:

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

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue項目中實現(xiàn)帶參跳轉(zhuǎn)功能

    Vue項目中實現(xiàn)帶參跳轉(zhuǎn)功能

    最近做了一個手機端系統(tǒng),其中遇到了父頁面需要攜帶參數(shù)跳轉(zhuǎn)至子頁面的問題,現(xiàn)已解決,下面分享一下實現(xiàn)過程,感興趣的朋友一起看看吧
    2021-04-04
  • vue使用video.js進(jìn)行視頻播放功能

    vue使用video.js進(jìn)行視頻播放功能

    video.js是一個擁有h5背景的網(wǎng)絡(luò)視頻播放器,同時支持h5以及Flash視頻播放,這篇文章主要介紹了vue中使用video.js進(jìn)行視頻播放,需要的朋友可以參考下
    2019-07-07
  • Vue中消息橫向滾動時setInterval清不掉的問題及解決方法

    Vue中消息橫向滾動時setInterval清不掉的問題及解決方法

    最近在做項目時,需要進(jìn)行兩個組件聯(lián)動,一個輪詢獲取到消息,然后將其傳遞給另外一個組件進(jìn)行橫向滾動展示,結(jié)果滾動的速度越來越快。接下來通過本文給大家分享Vue中消息橫向滾動時setInterval清不掉的問題及解決方法,感興趣的朋友一起看看吧
    2019-08-08
  • vue3如何實現(xiàn)掛載并使用axios

    vue3如何實現(xiàn)掛載并使用axios

    這篇文章主要介紹了vue3如何實現(xiàn)掛載并使用axios,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Vue?h函數(shù)的使用詳解

    Vue?h函數(shù)的使用詳解

    本文主要介紹了Vue?h函數(shù)的使用詳解,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • vue-router之實現(xiàn)導(dǎo)航切換過渡動畫效果

    vue-router之實現(xiàn)導(dǎo)航切換過渡動畫效果

    今天小編就為大家分享一篇vue-router之實現(xiàn)導(dǎo)航切換過渡動畫效果,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • Vue實現(xiàn)web分頁組件詳解

    Vue實現(xiàn)web分頁組件詳解

    這篇文章主要為大家詳細(xì)介紹了Vue實現(xiàn)web分頁組件的實現(xiàn)方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • vue父子組件傳值以及單向數(shù)據(jù)流問題詳解

    vue父子組件傳值以及單向數(shù)據(jù)流問題詳解

    大家應(yīng)該都知道父組件可以向子組件通過屬性形式傳遞參數(shù),傳遞的參數(shù)也可以隨時隨意修改;但子組件不能修改父組件傳遞過來的參數(shù),所以下面這篇文章主要給大家介紹了關(guān)于vue父子組件傳值以及單向數(shù)據(jù)流問題的相關(guān)資料,需要的朋友可以參考下
    2021-09-09
  • vue+springboot實現(xiàn)項目的CORS跨域請求

    vue+springboot實現(xiàn)項目的CORS跨域請求

    這篇文章主要介紹了vue+springboot實現(xiàn)項目的CORS跨域請求,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • vue項目首屏打開速度慢的解決方法

    vue項目首屏打開速度慢的解決方法

    這篇文章主要介紹了vue項目首屏打開速度慢的解決方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-03-03

最新評論