ホームページ > ウェブフロントエンド > jsチュートリアル > Vue のメソッドとイベント処理に関する問題

Vue のメソッドとイベント処理に関する問題

一个新手
リリース: 2017-10-24 10:54:04
オリジナル
1645 人が閲覧しました

メソッドとイベント ハンドラー

メソッド ハンドラー

v-on ディレクティブを使用して DOM イベントをリッスンできます: v-on 指令监听 DOM 事件:

<p id="example">
  <button v-on:click="greet">Greet</button>
</p>
ログイン後にコピー

我们绑定了一个单击事件处理器到一个方法 greet。下面在 Vue 实例中定义这个方法:

var vm = new Vue({
  el: &#39;#example&#39;,
  data: {
    name: &#39;Vue.js&#39;
  },
  // 在 `methods` 对象中定义方法
  methods: {
    greet: function (event) {
      // 方法内 `this` 指向 vm
      alert(&#39;Hello &#39; + this.name + &#39;!&#39;)
      // `event` 是原生 DOM 事件
      alert(event.target.tagName)
    }
  }
})

// 也可以在 JavaScript 代码中调用方法
vm.greet() // -> &#39;Hello Vue.js!&#39;
ログイン後にコピー

内联语句处理器

除了直接绑定到一个方法,也可以用内联 JavaScript 语句:

<p id="example-2">
  <button v-on:click="say(&#39;hi&#39;)">Say Hi</button>
  <button v-on:click="say(&#39;what&#39;)">Say What</button>
</p>

new Vue({
  el: &#39;#example-2&#39;,
  methods: {
    say: function (msg) {
      alert(msg)
    }
  }
}
ログイン後にコピー

类似于内联表达式,事件处理器限制为一个语句。

有时也需要在内联语句处理器中访问原生 DOM 事件。可以用特殊变量 $event 把它传入方法:

<button v-on:click="say(&#39;hello!&#39;, $event)">Submit</button>
ログイン後にコピー
// ...
methods: {
  say: function (msg, event) {
    // 现在我们可以访问原生事件对象
    event.preventDefault()
  }
}
ログイン後にコピー

事件修饰符

在事件处理器中经常需要调用 event.preventDefault()event.stopPropagation()。尽管我们在方法内可以轻松做到,不过让方法是纯粹的数据逻辑而不处理 DOM 事件细节会更好。

为了解决这个问题,Vue.js 为 v-on 提供两个 事件修饰符:.prevent.stop。你是否还记得修饰符是点号打头的指令后缀?

<!-- 阻止单击事件冒泡 -->
<a v-on:click.stop="doThis"></a>

<!-- 提交事件不再重载页面 -->
<form v-on:submit.prevent="onSubmit"></form>

<!-- 修饰符可以串联 -->
<a v-on:click.stop.prevent="doThat">

<!-- 只有修饰符 -->
<form v-on:submit.prevent></form>
ログイン後にコピー

1.0.16 添加了两个额外的修饰符:

<!-- 添加事件侦听器时使用 capture 模式 -->
<p v-on:click.capture="doThis">...</p>

<!-- 只当事件在该元素本身(而不是子元素)触发时触发回调 -->
<p v-on:click.self="doThat">...</p>
ログイン後にコピー

按键修饰符

在监听键盘事件时,我们经常需要检测 keyCode。Vue.js 允许为 v-on 添加按键修饰符:

<!-- 只有在 keyCode 是 13 时调用 vm.submit() -->
<input v-on:keyup.13="submit">
ログイン後にコピー

记住所有的 keyCode 比较困难,Vue.js 为最常用的按键提供别名:

<!-- 同上 -->
<input v-on:keyup.enter="submit">

<!-- 缩写语法 -->
<input @keyup.enter="submit">
ログイン後にコピー

全部的按键别名:

enter
tab
delete
esc
space
up
down
left
right
ログイン後にコピー

1.0.8+: 支持单字母按键别名。

1.0.17+: 可以自定义按键别名:

// 可以使用 @keyup.f1
Vue.directive(&#39;on&#39;).keyCodes.f1 = 112
ログイン後にコピー

为什么在 HTML 中监听事件?

你可能注意到这种事件监听的方式违背了传统理念 “separation of concern”。不必担心,因为所有的 Vue.js 事件处理方法和表达式都严格绑定在当前视图的 ViewModel 上,它不会导致任何维护困难。实际上,使用 v-onrrreee

クリック イベント ハンドラーをメソッド greet にバインドします。コード>。以下の Vue インスタンスでこのメソッドを定義します: <ol class=" list-paddingleft-2">rrreee<li>インライン ステートメント プロセッサ<p></p> メソッドに直接バインドすることに加えて、インライン JavaScript ステートメントを使用することもできます: </li>rrreee<li> インライン式と同様に、イベント ハンドラーはステートメントに限定されます。 <p></p>インライン ステートメント ハンドラーでネイティブ DOM イベントにアクセスする必要がある場合もあります。特別な変数 <code>$event を使用して、それをメソッドに渡すことができます: rrreeerrreee
  • イベント修飾子

    イベント ハンドラーでは、多くの場合、event.preventDefault() を呼び出す必要があります。またはevent.stopPropagation()。これはメソッド内で簡単に実行できますが、DOM イベントの詳細を処理せずにメソッドを純粋なデータ ロジックにする方が良いでしょう。
  • この問題を解決するために、Vue.js は v-on.prevent.stop という 2 つのイベント修飾子を提供します。修飾子はピリオドで始まるコマンド接尾辞であることをまだ覚えていますか? 🎜rrreee🎜1.0.16 では、2 つの追加の修飾子が追加されています: 🎜rrreee🎜キー修飾子🎜🎜 キーボード イベントをリッスンするとき、多くの場合、keyCode を検出する必要があります。 Vue.js では、v-on にキー修飾子を追加できます: 🎜rrreee🎜keyCode をすべて覚えるのは困難ですが、Vue.js は最もよく使用されるキーのエイリアスを提供します: 🎜rrreee

    すべてのボタン エイリアス: 🎜rrreee🎜1.0.8+: 1 文字のボタン エイリアスをサポートします。 🎜🎜1.0.17+: キーのエイリアスをカスタマイズできます: 🎜rrreee🎜なぜ HTML でイベントをリッスンするのですか?🎜🎜 このイベント監視の方法が、「関心の分離」という従来の概念に反していることに気づくかもしれません。心配しないでください。すべての Vue.js イベント ハンドラーと式は現在のビューの ViewModel に厳密にバインドされているため、メンテナンスが困難になることはありません。実際、v-on の使用にはいくつかの利点があります: 🎜🎜🎜🎜HTML テンプレートをスキャンすることで、JavaScript コード内の対応するメソッドを簡単に見つけることができます。 🎜🎜🎜🎜JavaScript でイベントを手動でバインドする必要がないため、ViewModel コードは非常に純粋なロジックとなり、DOM から完全に切り離され、テストが容易になります。 🎜🎜🎜🎜 ViewModel が破棄されると、すべてのイベント ハンドラーが自動的に削除されます。自分で掃除することを心配する必要はありません。 🎜🎜🎜

    以上がVue のメソッドとイベント処理に関する問題の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    関連ラベル:
    ソース:php.cn
    このウェブサイトの声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
    最新の問題
    人気のチュートリアル
    詳細>
    最新のダウンロード
    詳細>
    ウェブエフェクト
    公式サイト
    サイト素材
    フロントエンドテンプレート