vue broadcast和dispatch

function broadcast(componentName, eventName, params) {
this.$children.forEach((child) => {
const name = child.$options.componentName;

if (name === componentName) {
child.$emit(...[eventName].concat(params));
} else {
broadcast.apply(child, [componentName, eventName].concat([params]));
}
});
}
export default {
methods: {
dispatch(componentName, eventName, params) {
let parent = this.$parent || this.$root;
let name = parent.$options.componentName;

while (parent && (!name || name !== componentName)) {
parent = parent.$parent;

if (parent) {
name = parent.$options.componentName;
}
}
if (parent) {
parent.$emit(...[eventName].concat(params));
}
},
broadcast(componentName, eventName, params) {
broadcast.call(this, componentName, eventName, params);
},
},
};

posted @ 2023-11-08 22:00  吃饭七分饱  阅读(21)  评论(0编辑  收藏  举报