当前位置:网站首页>vue任意关系组件通信与跨组件监听状态 vue-communication
vue任意关系组件通信与跨组件监听状态 vue-communication
2020-11-06 20:48:00 【木瓜太香】
大家好!我是木瓜太香!
众所周知,组件式开发方式给我们带来了方便,不过也引入了新的问题,组件之间的数据就像被一道无形的墙隔开,如果我们希望临时让两个组件直接通信,vuex 太巨,而 $emit 又不好维护 provider 不可控 这个时候就该今天的主角 vue-communication 登场了!
vue-communication介绍
- 他是一个可观测可调试的vue组件通信方案
- 任意关系组件可直接通信
- 支持跨组件监听数据变化
- 支持发送离线数据
安装
yarn add vue-communication
// 或者 npm install vue-communication -D
引入
import { $sender, $receiver } "vue-communication";
Vue.prototype.$sender = $sender;
Vue.prototype.$receiver = $receiver;
视频教程
用法
基本概念:
该组件暴露两个主要 API 一个是发送者 $sender
一个是接受者 $receiver
,所有的通信都通过这两个方法来实现,这里希望大家将 $sender
理解成发送意图的发送者,他发送的是意图,意图就是希望做一件什么事情。
意图类型: dataOnce
modifyOnce
data
modify
watch
目前只有以上5种意图分别涵盖了:发送数据的一次和多次,修改数据的一次和多次,跨组件监听数据变化
发送数据:
假如 A 组件只向 B 组件发送一次
数据:
A 组件中直接使用 this.$sender("dataOnce-A-B",{d: "我是数据"})
B 组件中在任意时刻(哪怕B都还没挂载都行,放心食用)使用this.$receiver("dataOnce-A-B")
这个函数返回一个 Promise 对象,直接 .then 接收即可
发送多次就用 this.$sender("data-A-B","我是数据")
,该方法调用多次,对应组件就会多次接收该数据
接收会有变化,由于会多次接收所以无法使用 Promise 来实现,请在参数追加回调this.$receiver("data-A-B",function(data){ // data就是数据 })
注意:
这里面的 意图修饰符-组件1-组件2
的格式是强制的,不管你的组件名有多长,你都要完整的给出!下面的修改数据也一样,对应到 data-A-B 这个案例,其整个字符串可以称为一个“意图”,data 叫做意图修饰符。
接收回执:
我相信大家都明白一个道理,如果委托 A 给 B 送东西,在 A 送到之后不应该默不吭声的就完了,而是应该告诉你一声,嘿!你让我送的东西我已经送到了哦!这就是回执。
需要注意的是回执目前只有在一次性操作中才会有,例如 dataOnce
modifyOnce
他们通过 $sender
返回的 Promise 对象给出,让发送者可以知道,我发送的数据什么时候被接收了
this.$sender("dataOnce-A-B","木瓜太香")
.then(flag => {
console.log("接受者已经接受到数据了!")
})
修改数据:
A 组件中使用 this.$sender("modifyOnce-A-B","name","木瓜太香")
表示 A 组件要修改 B 组件中的 name 属性把他变为 木瓜太香
B组件中使用 this.$receiver("modifyOnce-A-B","name")
即可完成修改,注意第二个参数必须传,这是一个许可,表示你认可 A 组件修改当前组件的 name 属性,如果你写错了或者没传那么许可不成立,这是一个让数据变动可预测也强迫开发者需要更清楚自己在做什么的一个实现。
如果你要改 obj 对象下的 name 那么可以写成 this.$sender("modifyOnce-A-B","obj.name","木瓜太香")
如果你要修改多次可以参照 data 意图的示例,使用 modify 意图修饰符即可,注意,目前修改是没有回调的,如果你想知道数据什么时候被修改,可以自己在组件内部监听。
跨组件监听数据:
假如 A 组件要监听 B 组件中的 name 数据变动:
A 组件使用 this.$sender("watch-A-B","person.name",function(nv,ov){ // nv 表示新值 ov 表示旧值 })
B 组件只需要给出一次许可即可: this.$receiver("watch-A-B","person.name")
我自己建了一个web前端的交流裙有兴趣的可以加入进来交流哦:245650187(免费)237871108(收费)。 个人微信: GD6570 个人球球:718879459 当然你也可以哔哩哔哩搜索木瓜太香
版权声明
本文为[木瓜太香]所创,转载请带上原文链接,感谢
https://my.oschina.net/u/4642048/blog/4678611
边栏推荐
- Summary of common algorithms of linked list
- Network security engineer Demo: the original * * is to get your computer administrator rights! 【***】
- “颜值经济”的野望:华熙生物净利率六连降,收购案遭上交所问询
- From zero learning artificial intelligence, open the road of career planning!
- 至联云分享:IPFS/Filecoin值不值得投资?
- Working principle of gradient descent algorithm in machine learning
- 关于Kubernetes 与 OAM 构建统一、标准化的应用管理平台知识!(附网盘链接)
- Serilog原始碼解析——使用方法
- ES6学习笔记(五):轻松了解ES6的内置扩展对象
- Classical dynamic programming: complete knapsack problem
猜你喜欢
Aprelu: cross border application, adaptive relu | IEEE tie 2020 for machine fault detection
怎么理解Python迭代器与生成器?
Do not understand UML class diagram? Take a look at this edition of rural love class diagram, a learn!
华为云“四个可靠”的方法论
钻石标准--Diamond Standard
JVM memory area and garbage collection
Python自动化测试学习哪些知识?
How long does it take you to work out an object-oriented programming interview question from Ali school?
Filecoin最新动态 完成重大升级 已实现四大项目进展!
向北京集结!OpenI/O 2020启智开发者大会进入倒计时
随机推荐
Relationship between business policies, business rules, business processes and business master data - modern analysis
教你轻松搞懂vue-codemirror的基本用法:主要实现代码编辑、验证提示、代码格式化
Troubleshooting and summary of JVM Metaspace memory overflow
10 easy to use automated testing tools
Network security engineer Demo: the original * * is to get your computer administrator rights! 【***】
Skywalking series blog 1 - install stand-alone skywalking
Vue 3 responsive Foundation
5.4 static resource mapping
使用 Iceberg on Kubernetes 打造新一代云原生数据湖
一篇文章带你了解CSS3圆角知识
熬夜总结了报表自动化、数据可视化和挖掘的要点,和你想的不一样
The choice of enterprise database is usually decided by the system architect - the newstack
DevOps是什么
人工智能学什么课程?它将替代人类工作?
Examples of unconventional aggregation
前端基础牢记的一些操作-Github仓库管理
[JMeter] two ways to realize interface Association: regular representation extractor and JSON extractor
Leetcode's ransom letter
“颜值经济”的野望:华熙生物净利率六连降,收购案遭上交所问询
Existence judgment in structured data