源代码
function broadcast(componentName, eventName, params) {
this.$children.forEach(child => {
var name = child.$options.componentName;
if (name === componentName) {
child.$emit.apply(child, [eventName].concat(params));
} else {
broadcast.apply(child, [componentName, eventName].concat([params]));
}
});
}
export default {
methods: {
/**
* 不停的向上去遍历父节点并且通过$emit去触发事件,到达根节点之后停止
**/
dispatch(componentName, eventName, params) {
var parent = this.$parent || this.$root;
var name = parent.$options.componentName;
while (parent && (!name || name !== componentName)) {
parent = parent.$parent;
if (parent) {
name = parent.$options.componentName;
}
}
if (parent) {
parent.$emit.apply(parent, [eventName].concat(params));
}
},
/**
* 不停的去遍历子节点并且通过$emit去触发事件,直到所有的子节点遍历完成之后停止
**/
broadcast(componentName, eventName, params) {
broadcast.call(this, componentName, eventName, params);
}
}
};
dispatch, broadcast
dispatch(componentName, eventName, params): 不停的向上去遍历父节点并且通过$emit去触发事件,到达根节点之后停止
broadcast(componentName, eventName, params): 不停的去遍历子节点并且通过$emit去触发事件,直到所有的子节点遍历完成之后停止
$emit, $on
$emit(eventName, […args]): 在组件中抛出自定义事件
$on(eventName, callback): 捕获当前组件中抛出的自定义事件