Skip to content
ページの内容

emits オプション
新機能

概要

Vue 3 では、既存の props オプションと同様に、emits オプションを提供するようになりました。このオプションを使用してコンポーネントが親に発行可能なイベントを定義できます。

2.x の動作

Vue 2 ではコンポーネントが受け取るプロパティを定義できますが、そのコンポーネントが発行可能なイベントは宣言できません:

vue
<template>
  <div>
    <p>{{ text }}</p>
    <button v-on:click="$emit('accepted')">OK</button>
  </div>
</template>
<script>
  export default {
    props: ['text']
  }
</script>

3.x の動作

プロパティと同様に、コンポーネントが発行するイベントを emits オプションで定義できるようになりました:

vue
<template>
  <div>
    <p>{{ text }}</p>
    <button v-on:click="$emit('accepted')">OK</button>
  </div>
</template>
<script>
  export default {
    props: ['text'],
    emits: ['accepted']
  }
</script>

このオプションにはオブジェクトも指定できます。開発者は、props 定義のバリデーターと同じように、発行されるイベントに渡される引数のバリデーターを定義できます。

詳細については、この機能の API ドキュメントをお読みください。

移行手順

emits を使って、各コンポーネントが発行するすべてのイベントをドキュメント化することを強くお勧めします。

特に、.native 修飾子が削除されるため重要です。emits で宣言されていないイベントリスナーは、コンポーネントの $attrs に含まれるようになり、デフォルトではコンポーネントのルートノードにバインドされます。

ネイティブイベントを親に再発行するコンポーネントの場合、2 つのイベントが発生することになります:

vue
<template>
  <button v-on:click="$emit('click', $event)">OK</button>
</template>
<script>
export default {
  emits: [] // イベント宣言なし
}
</script>

親がコンポーネントの click イベントを購読する場合:

html
<my-button v-on:click="handleClick"></my-button>

これは2 回トリガーされます:

  • $emit() から 1 回。
  • ルート要素に適用されるネイティブイベントリスナーから 1 回。

ここで、2 つの選択肢があります:

  1. click イベントを適切に宣言する。これは実際に <my-button> のイベントハンドラーに何らかのロジックを追加する場合に便利です。
  2. イベントの再発行を削除する。.native を追加しなくても、親は簡単にネイティブイベントを購読できるようになりました。とにかくイベントを再発行するだけの場合に適しています。

参照