微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

vue ElementUI中dispatch和broadcast事件派发通过mixin引入使用

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: {   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));     }   },   broadcast(componentName, eventName, params) {     broadcast.call(this, componentName, eventName, params);   }  } };

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐