详解vue之自行实现派发与广播(dispatch与broadcast)


Posted in Vue.js onJanuary 19, 2021

要解决的问题

主要针对组件之间的跨级通信

为什么要自己实现dispatch与broadcast?

因为在做独立组件开发或库时,最好是不依赖第三方库

为什么不使用provide与inject?

因为它的使用场景,主要是子组件获取上级组件的状态,跨级组件间建立了一种主动提供与依赖注入的关系。
然后有两种场景它不能很好的解决:
父组件向子组件(支持跨级)传递数据;
子组件向父组件(支持跨级)传递数据。

代码如下:

emitter.js

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

  if (name === componentName) {
   child.$emit.apply(child, [eventName].concat(params));
  } else {
   // todo 如果 params 是空数组,接收到的会是 undefined
   broadcast.apply(child, [componentName, eventName].concat([params]));
  }
 });
}
export default {
 methods: {
  dispatch(componentName, eventName, params) {
   let parent = this.$parent || this.$root;
   let name = parent.$options.name;

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

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

parent.vue

<template>
 <div>
  <h1>我是父组件</h1>
  <button @click="handleClick">触发事件</button> <child />
 </div>
</template>
<script>
import Emitter from "@/mixins/emitter.js";
import Child from "./child";
export default {
 name: "componentA",
 mixins: [Emitter],
 created() {
  this.$on("child-to-p", this.handleChild);
 },
 methods: {
  handleClick() {
   this.broadcast("componentB", "on-message", "Hello Vue.js");
  },
  handleChild(val) {
   alert(val);
  }
 },
 components: {
  Child
 }
};
</script>

child.vue

<template>
 <div>我是子组件</div>
</template>
<script>
import Emitter from "@/mixins/emitter.js";
export default {
 name: "componentB",
 mixins: [Emitter],
 created() {
  this.$on("on-message", this.showMessage);
  this.dispatch("componentA", "child-to-p", "hello parent");
 },
 methods: {
  showMessage(text) {
   window.alert(text);
  }
 }
};
</script>

这样就能实现跨级组件自定义通信了,但是,要注意其中一个问题:订阅必须先于发布,也就是说先有on再有emit

父子组件渲染顺序,实例创建顺序

子组件先于父组件前渲染,所以在子组的mounted派发事件时,在父组件中的mounte中是监听不到的。
而父组件的create是先于子组件的,所以可以在父组件中的create可以监听到

到此这篇关于详解vue之自行实现派发与广播(dispatch与broadcast)的文章就介绍到这了,更多相关vue 派发与广播内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Vue.js 相关文章推荐
Vue用mixin合并重复代码的实现
Nov 27 Vue.js
vue element实现表格合并行数据
Nov 30 Vue.js
vue 实现基础组件的自动化全局注册
Dec 25 Vue.js
浅谈Vue开发人员的7个最好的VSCode扩展
Jan 20 Vue.js
如何在Vue项目中添加接口监听遮罩
Jan 25 Vue.js
vue 项目@change多个参数传值多个事件的操作
Jan 29 Vue.js
解决vue项目本地启动时无法携带cookie的问题
Feb 06 Vue.js
Vue基本指令实例图文讲解
Feb 25 Vue.js
浅谈vue2的$refs在vue3组合式API中的替代方法
Apr 18 Vue.js
Vue和Flask通信的实现
May 19 Vue.js
Vue h函数的使用详解
Feb 18 Vue.js
vue3 自定义图片放大器效果的示例代码
Jul 23 Vue.js
vue二选一tab栏切换新做法实现
Jan 19 #Vue.js
vue-resource 拦截器interceptors使用详解
Jan 18 #Vue.js
vue element el-transfer增加拖拽功能
Jan 15 #Vue.js
Vue实现多页签组件
Jan 14 #Vue.js
如何在vue中使用HTML 5 拖放API
Jan 14 #Vue.js
Vue中引入svg图标的两种方式
Jan 14 #Vue.js
vue+element table表格实现动态列筛选的示例代码
Jan 14 #Vue.js
You might like
电脑硬件及电脑配置知识大全
2020/03/17 数码科技
用PHP与XML联手进行网站编程代码实例
2008/07/10 PHP
浅谈apache和nginx的rewrite的区别
2013/02/22 PHP
PHP文件操作方法汇总
2015/07/01 PHP
php四种定界符详解
2017/02/16 PHP
PHP使用xpath解析XML的方法详解
2017/05/20 PHP
让焦点自动跳转
2006/07/01 Javascript
获取URL地址中的文件名和参数的javascript代码
2009/09/02 Javascript
js实现快速分享功能(你的文章分享工具)
2013/06/25 Javascript
document.getElementBy(&quot;id&quot;)与$(&quot;#id&quot;)有什么区别
2013/09/22 Javascript
零基础搭建Node.js、Express、Ejs、Mongodb服务器及应用开发入门
2014/12/20 Javascript
JavaScript常用脚本汇总(三)
2015/03/04 Javascript
easyui-combobox 实现简单的自动补全功能示例
2016/11/08 Javascript
BootStrap与Select2使用小结
2017/02/17 Javascript
el-select 下拉框多选实现全选的实现
2019/08/02 Javascript
非常漂亮的js烟花效果
2020/03/10 Javascript
处理JavaScript值为undefined的7个小技巧
2020/07/28 Javascript
vue实现一个获取按键展示快捷键效果的Input组件
2021/01/13 Vue.js
Python实现小数转化为百分数的格式化输出方法示例
2017/09/20 Python
python+pyqt5实现24点小游戏
2019/01/24 Python
Python中使用pypdf2合并、分割、加密pdf文件的代码详解
2019/05/21 Python
Python解析微信dat文件的方法
2020/11/30 Python
娱乐地球:Entertainment Earth
2020/01/08 全球购物
公司薪酬管理制度
2014/01/31 职场文书
音乐教学随笔感言
2014/02/19 职场文书
幼儿园大班区域活动总结
2014/07/09 职场文书
科技工作者先进事迹
2014/08/16 职场文书
园艺专业毕业生求职信
2014/09/02 职场文书
岳庙导游词
2015/02/04 职场文书
事业单位年度考核个人总结
2015/02/12 职场文书
退税申请报告怎么写
2015/05/18 职场文书
毕业生政审意见范文
2015/06/04 职场文书
解决hive中导入text文件遇到的坑
2021/04/07 Python
SpringBoot2零基础到精通之数据库专项精讲
2022/03/22 Java/Android
Python中time与datetime模块使用方法详解
2022/03/31 Python
Python探索生命起源 matplotlib细胞自动机动画演示
2022/04/21 Python