是否可以發出自定義事件從指令在該指令附加到的組件。Vue.js - 來自指令
我期待它按照例子中的描述工作,但事實並非如此。
例子:
//Basic Directive
<script>
Vue.directive('foo', {
bind(el, binding, vnode) {
setTimeout(() => {
//vnode.context.$emit('bar'); <- this will trigger in parent
vnode.$emit('bar');
}, 3000);
}
});
</script>
//Basic Component
<template>
<button v-foo @bar="change">{{label}}</button>
</template>
<script>
export default{
data() {
return {
label: 'i dont work'
}
},
methods: {
change() {
this.label = 'I DO WORK!';
}
}
}
</script>
對此事的任何想法?我錯過了什麼嗎?
的jsfiddle:https://jsfiddle.net/0aum3osq/4/
更新1:
好吧,我發現,如果我在指令調用vnode.data.on.bar.fn();
(或fns()
在最新版本的Vue公司),它會觸發bar
事件處理程序。
更新2:
臨時解決方法:
/*temp. solution*/
var emit = (vnode, name, data) => {
var handlers = vnode.data.on;
if (handlers && handlers.hasOwnProperty(name)) {
var handler = handlers[name];
var fn = handler.fns || handler.fn;
if (typeof fn === 'function') {
fn(data);
}
}
}
//Basic Directive
<script>
Vue.directive('foo', {
bind(el, binding, vnode) {
setTimeout(() => {
emit(vnode, 'bar');
}, 3000);
}
});
</script>
很好用!您的emit函數調用缺少結束括號。我試圖編輯,但是SO說我必須編輯6個字符。 –
'vnode.context。$ emit()'在[email protected]下的這個例子中不起作用,該如何解決?但排放功能仍然運作良好。 –
根據我的經驗,你只能叫'vnode.context。$發出( '名稱')'後事件已派出... 'element.addEvenetListener( '點擊',()=> { vnode.context 。$ emit('handleClick');});' 工程!但是,在事件觸發器之外做一個簡單的'vnode.context。$ emit('handleClick')' 實際上並沒有調用正確的發射,因此你不能聽它。我可能是錯的,但這是我剛剛[email protected]所經歷的。 – djowinz