很多人对于Vue实战指南都不是很熟悉,操作的时候也感觉困难重重,弄得一团乱。因此小编特意查询了资料之后整理了比较具有参考价值的部分,感觉里面的依赖注入使用起来还是很方便的,下面给大家详细解说下教程,希望对大家有所帮助。
案例
UI美眉说咱家的选项菜单太丑了,小哥哥能不能美化一下呀,洒家自然是说小意思啦~
自定义一个select组件,so easy~
简单粗暴型:

option作为数据进来就ok啦。
然后发现下列问题:
key-value,不是所有的接口都是id-name
option要disabled 怎么办?
option存在几种情况怎么办?
...
回头看看原生的写法是这样:

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

好啦,这样设计就能完美解决之前的几个问题。
接着要解决选择了某一个el-option,怎么告诉el-select,$parent是一种选择,那么el-select当前的值又怎么告诉el-option你被选中了呢~ 笔者没有继续去深究,因为看到了APIprovide/inject
官方说明:
允许一个祖先组件向其所有子孙后代注入一个依赖,不论组件层次有多深(这也是使用$parent不好实现的地方),并在起上下游关系成立的时间里始终生效。
不论组件层次有多深,这个简直太爽了,不用再关心dom层级,只要在祖先组件内部就可以一直使用祖先组件提供的provide
用法
下面贴出一部分select的实现:
provide:Object | () => Object
inject:Array<string> | { [key: string]: string | Symbol | Object }
el-select

el-option

总结
provide/inject 是解决组件之间的通信问题的利器,不受层级结构的限制。
但也不是随便去滥用,通信代表着耦合:
provide 和 inject 主要为高阶插件/组件库提供用例。并不推荐直接用于应用程序代码中。
如果大家对于选项菜单的设计感觉不是很满意的话就可以运用上面的方法来进行操作,你会发现是否简单快捷。今天的分享就到这里了,如果大家还有其他的疑问的话可以联系小编交流探讨。