vue/require-explicit-emits
require
emits
option with name triggered by$emit()
- ⚙️ This rule is included in
"plugin:vue/vue3-strongly-recommended"
and"plugin:vue/vue3-recommended"
. - 💡 Some problems reported by this rule are manually fixable by editor suggestions.
📖 Rule Details
This rule reports event triggers not declared with the emits
option. (The emits
option is a new in Vue.js 3.0.0+)
Explicit emits
declaration serves as self-documenting code. This can be useful for other developers to instantly understand what events the component is supposed to emit. Also, with attribute fallthrough changes in Vue.js 3.0.0+, v-on
listeners on components will fallthrough as native listeners by default. Declare it as a component-only event in emits
to avoid unnecessary registration of native listeners.
🔧 Options
json
{
"vue/require-explicit-emits": ["error", {
"allowProps": false
}]
}
"allowProps"
... Iftrue
, allow event names defined inprops
. defaultfalse
"allowProps": true
👫 Related Rules
📚 Further Reading
🚀 Version
This rule was introduced in eslint-plugin-vue v7.0.0