在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 教程/ HTML/ 事件監(jiān)聽(tīng)
過(guò)濾器
起步
自定義指令
事件監(jiān)聽(tīng)
安裝
過(guò)渡效果
計(jì)算屬性
細(xì)節(jié)與最佳實(shí)踐
創(chuàng)建大型應(yīng)用
指令
常見(jiàn)問(wèn)題
處理表單
自定義過(guò)濾器
組件系統(tǒng)
擴(kuò)展 Vue
列表渲染

事件監(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.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>
</ul>
new Vue({
  el: '#list',
  data: {
    items: [
      { text: 'one', done: true },
      { text: 'two', done: false }
    ]
  },
  methods: {
    toggle: function (item) {
      item.done = !item.done
    }
  }
})

當(dāng)你想要在表達(dá)式中訪問(wèn)原來(lái)的 DOM event,你可以傳遞一個(gè) $event 參數(shù)進(jìn)去:

<button v-on="click: submit('hello!', $event)">Submit</button>

/* ... */
{
  methods: {
    submit: function (msg, e) {
      e.stopPropagation()
    }
  }
}
/* ... */

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:submit | key 13">

它也預(yù)置了一些常用的按鍵名:

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

查看 API 參考:key 過(guò)濾器的全部預(yù)設(shè)參數(shù)。

為什么要在 HTML 中寫(xiě)監(jiān)聽(tīng)器?

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

  1. 它便于在 HTML 模板中輕松定位 JS 代碼里的對(duì)應(yīng)方法實(shí)現(xiàn)。

  2. 因?yàn)槟銦o(wú)須在 JS 里手動(dòng)綁定事件,你的 ViewModel 代碼可以是非常純粹的邏輯,和 DOM 完全解耦。這會(huì)更易于測(cè)試。

  3. 當(dāng)一個(gè) ViewModel 被銷(xiāo)毀時(shí),所有的事件監(jiān)聽(tīng)都會(huì)被自動(dòng)移除。你無(wú)須擔(dān)心如何自行清理它們。

下一步:處理表單。