A<div>
不是 a VueComponent
,这意味着它没有$emit
方法。
所以要让你的 Vue 自定义指令发出一个事件,你必须先做一些检查:
- 如果该指令在Vue 自定义组件中使用,则调用
$emit()
该组件的实例
- 如果该指令用于常规 DOM 元素(...因为没有
$emit()
...),则使用.dispatch 本地 DOM 事件.dispatchEvent
。
幸运的是,Vue 的v-on
侦听器响应原生自定义事件。
这应该就是全部了。下面的演示实现。
Vue.component('my-comp', {
template: `<input value="click me and check the console" size="40">`
});
Vue.directive('my-directive', {
bind: function (el, binding, vnode) {
// say you want to execute your logic when the element is clicked
el.addEventListener('click', function (e) {
var eventName = 'my-event';
var eventData = {myData: 'stuff - ' + binding.expression}
if (vnode.componentInstance) {
vnode.componentInstance.$emit(eventName, {detail: eventData}); // use {detail:} to be uniform
} else {
vnode.elm.dispatchEvent(new CustomEvent(eventName, {detail: eventData}));
}
})
}
})
new Vue({
el: '#app',
methods: {
handleStuff(e) { console.log('my-event received', e.detail); }
}
})
<script src="https://unpkg.com/vue@2.5.15/dist/vue.min.js"></script>
<div id="app">
<div v-my-directive.modifier="'native element'" @my-event="handleStuff">CLICK ME AND CHECK THE CONSOLE</div>
<hr>
<my-comp v-my-directive.modifier="'custom component'" @my-event="handleStuff"></my-comp>
</div>