首页 > 其他 > 详细

vue组件库封装 广播 $dispatch $broadcast

时间:2020-04-03 22:36:40      阅读:71      评论:0      收藏:0      [点我收藏+]

$dispatch和$broadcast源代码:

function broadcast (componentName, eventName, params) {
  this.$children.forEach(child => {
    const name = child.$options.name
    // 组件名与传入componentName一致
    if (name === componentName) {
      // 子组件触发eventName事件
      child.$emit.apply(child, [eventName].concat(params))
    } else {
            broadcast.apply(child, [componentName, eventName].concat([params])); // eslint-disable-line
    }
  })
}

export default {
  methods: {
    // 向上触发事件
    $dispatch (componentName, eventName, params) {
      // 获取父实例
      let parent = this.$parent || this.$root
      // 获取组件名
      let name = parent.$options.name
      // 递归查找与componentName一致的组件名
      while (parent && (!name || name !== componentName)) {
        parent = parent.$parent

        if (parent) {
          name = parent.$options.name
        }
      }
      if (parent) {
        // 组件触发eventName事件
        parent.$emit.apply(parent, [eventName].concat(params))
      }
    },
    // 向子(孙)组件发送事件
    $broadcast (componentName, eventName, params) {
      broadcast.call(this, componentName, eventName, params)
    }
  }
}

 

vue组件库封装 广播 $dispatch $broadcast

原文:https://www.cnblogs.com/mengfangui/p/12629173.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!