博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Vue实战指南之依赖注入(provide / inject)
阅读量:6529 次
发布时间:2019-06-24

本文共 1195 字,大约阅读时间需要 3 分钟。

案例

UI美眉说咱家的选项菜单太丑了,小哥哥能不能美化一下呀,洒家自然是说小意思啦~ 自定义一个select组件,so easy~

简单粗暴型:

复制代码

option作为数据进来就ok啦。

然后发现下列问题:

  • key-value,不是所有的接口都是id-name
  • optiondisabled 怎么办?
  • option存在几种情况怎么办?
  • ...

回头看看原生的写法是这样:

复制代码

还要加个el-option组件,灵活自由型:

Vue
React
Angular
复制代码

好啦,这样设计就能完美解决之前的几个问题。 接着要解决选择了某一个el-option,怎么告诉el-select$parent是一种选择,那么el-select当前的值又怎么告诉el-option你被选中了呢~ 笔者没有继续去深究,因为看到了API**provide/inject**

官方说明:

允许一个祖先组件向其所有子孙后代注入一个依赖,不论组件层次有多深(这也是使用$parent不好实现的地方),并在起上下游关系成立的时间里始终生效。

不论组件层次有多深,这个简直太爽了,不用再关心dom层级,只要在祖先组件内部就可以一直使用祖先组件提供的provide

用法

下面贴出一部分select的实现:

  • provideObject | () => Object
  • injectArray<string> | { [key: string]: string | Symbol | Object }

el-select

export default {  name: "el-select",  provide() {    return {      select: this    };  }}复制代码

el-option

export default {    name:'el-option',    inject:['select'],    created(){      if(this.select.value===this.value){        this.select.label=this.label;      }    }}复制代码

总结

provide/inject 是解决组件之间的通信问题的利器,不受层级结构的限制。 但也不是随便去滥用,通信代表着耦合:

provideinject 主要为高阶插件/组件库提供用例。并不推荐直接用于应用程序代码中。 官方文档:

转载于:https://juejin.im/post/5be9c7eb6fb9a049ef261e4b

你可能感兴趣的文章
CentOS 5.3 下快速安装配置 PPTP ××× 服务器
查看>>
产品经理学习总结之技术和设计篇
查看>>
23种设计模式(15):备忘录模式
查看>>
java基础学习总结——IO流
查看>>
iOS获取APP ipa 包以及资源文件
查看>>
CentOS 7 关闭启动防火墙
查看>>
Vue-选项卡切换
查看>>
linux网络命令
查看>>
nodejs ejs 请求路径和静态资源文件路径
查看>>
C++小代码
查看>>
记一次思维转变的时刻
查看>>
STL - Map - 运行期自定义排序
查看>>
Oil Deposits
查看>>
poj3984 迷宫问题(简单搜索+记录路径)
查看>>
Linux 服务器buff/cache清理
查看>>
算法试题 及其他知识点
查看>>
php课程---Json格式规范需要注意的小细节
查看>>
hadoop hdfs notes
查看>>
Java反射机制详解(3) -java的反射和代理实现IOC模式 模拟spring
查看>>
(2编写网络)自己动手,编写神经网络程序,解决Mnist问题,并网络化部署
查看>>