vue3项目同事用 provide+ref 组件实例进行跨组件通信 ,给我看傻了

前言

平常 你在开发过程中是不是经常会遇到这种场景:

一个页面共有多个区域, 头部区域和中间区域是兄弟组件 头部区域有一个 按钮 会修改 中间部分的内容

正常解决方案

正常我们的解决方案 无非就是 props搭配emit 或者bus 总线:mitt 或者 子组件emit出去父组件用ref获取组件实例去改参数等等,但是我同事不一样 后面会叙述

props+ emit

父组件

Header 组件

Content 组件

这个应该是平常我们用的比较多的方式对吧

  • 1)将 title变量提升到 父组件
  • 2)header组件将事件emit 出去 在父组件中修改 title 的值

emit + ref

省略 在header 中 点击事件中 emit 出去 在父组件利用 ref 获取 content 组件中的 实例 然后直接修改 title内容

mitt

这里就省略了 无非是借用了 mitt 的emit 事件 和 on 事件 发布订阅 进行修改数据

或者你还有其他的方案 我觉得 应该也是大差不差 主要看下面的方式

我同事的方案

重点到了 我看了同事的方案是 provide + inject + ref 实例的方式

父组件

Header 组件

Content 组件

他的思路是

  • 利用provide 在父组件中 获取所有子组件的实例
  • 利用 inject 将所有的子组件实例注入到所有的 给自的子组件中
  • 这样 就可以直接 利用注入的provideRefs 获取到其他ref实例 就可以直接去修改 对应组件中的参数 或者调用 内部的方法
  • 但是得注意 你必须要在子组件defineExpose 抛出你要修改的参数 或者 方法这样其他组件才能调用到

我看了之后 直呼一声:

总结

这种思路确实比较清奇 ,如果在 组件比较多、比较复杂的时候 ,跨组件通信 确实是比较麻烦的,你得写很多代码 各种 emit 各种 props 然后状态在父组件中 修改之后 同步到子组件中,举个例子:

场景一:

要是 header组件 按钮得调用 content的 刷新表格的方法的话 你八成得:

1、在父组件中 弄一个 fetchTableFlag 变量 传递到content 组件中

2、在header组件中 点击按钮的时候 emit 到父组件 去修改fetchTableFlag 的值

3、在 Content 组件中watch fetchTableFlag 的变化然后调用 刷新表格的方法

这样的交互多了话 可能就会导致会有很多变量 导致代码量增加 利用他的方法的话 某种程度上说确实 减少了不少代码

场景二:

如果组件有很多 不仅仅是这三种组件 比如 爷孙组件通信 或者兄弟组件有五六个的时候 你可能会考虑使用 pinia 但是 他们其实并没有多少的公用参数 可能只是这个组件改变了一下另一个组件的状态 给人感觉是不是放到 pinia 里面会比较重,用他的这种方式的话 就 就把传参扁平化了

但是我个人觉得这种方式,还是不推荐使用,因为他打破了vue 的单项数据流的规,导致数据流转不清晰,可是vue 既然创造了provide 和 ref 实例进行传参,那么自然有他存在的道理,我们同事之间对这种方式褒贬不一,jym 你们觉得呢?

相关推荐
香蕉可乐荷包蛋3 小时前
浅入ES5、ES6(ES2015)、ES2023(ES14)版本对比,及使用建议---ES6就够用(个人觉得)
前端·javascript·es6
未来之窗软件服务3 小时前
资源管理器必要性———仙盟创梦IDE
前端·javascript·ide·仙盟创梦ide
liuyang___4 小时前
第一次经历项目上线
前端·typescript
西哥写代码5 小时前
基于cornerstone3D的dicom影像浏览器 第十八章 自定义序列自动播放条
前端·javascript·vue
清风细雨_林木木5 小时前
Vue 中生成源码映射文件,配置 map
前端·javascript·vue.js
FungLeo5 小时前
node 后端和浏览器前端,有关 RSA 非对称加密的完整实践, 前后端匹配的代码演示
前端·非对称加密·rsa 加密·node 后端
不灭锦鲤5 小时前
xss-labs靶场第11-14关基础详解
前端·xss
不是吧这都有重名6 小时前
利用systemd启动部署在服务器上的web应用
运维·服务器·前端
霸王蟹6 小时前
React中巧妙使用异步组件Suspense优化页面性能。
前端·笔记·学习·react.js·前端框架
Maỿbe6 小时前
利用html制作简历网页和求职信息网页
前端·html