Vue实战指南之依赖注入(provide / inject)
2024-09-29 23:45:16
案例
UI美眉说咱家的选项菜单太丑了,小哥哥能不能美化一下呀,洒家自然是说小意思啦~
自定义一个select
组件,so easy~
简单粗暴型:
<el-select v-model="favourite" :option="[]"></el-select>
option
作为数据进来就ok啦。
然后发现下列问题:
key-value
,不是所有的接口都是id-name
option
要disabled
怎么办?option
存在几种情况怎么办?- ...
回头看看原生的写法是这样:
<select v-model="favourite">
<option value="1">Vue</option>
<option value="2">React</option>
<option value="3">Angular</option>
</select>
还要加个el-option
组件,灵活自由型:
<el-select v-model="favourite">
<el-option value="1">Vue</el-option>
<el-option value="2">React</el-option>
<el-option value="3">Angular</el-option>
</el-select>
好啦,这样设计就能完美解决之前的几个问题。
接着要解决选择了某一个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
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
是解决组件之间的通信问题的利器,不受层级结构的限制。
但也不是随便去滥用,通信代表着耦合:
provide
和inject
主要为高阶插件/组件库提供用例。并不推荐直接用于应用程序代码中。
官方文档:
https://cn.vuejs.org/v2/api/#...
https://cn.vuejs.org/v2/guide...
原文地址:https://segmentfault.com/a/1190000016990239
最新文章
- AJAX请求时status返回状态明细表 readyState的五种状态
- 利用firebug调试功能辅助了解闭包和this
- 2016 CCPC长春重现赛
- Android学习笔记----Activity的生命周期图示
- TestPointer
- linx 实用操作命令一
- JAVA去掉字符串前面的0
- indexedDB bootstrap angularjs 前端 MVC Demo
- mysql explain 分析sql语句
- freemarker字符串拼接
- flex练习---纵横中文网
- NSIS控制面板中显示安装包的大小和禁止多个安装程序实例
- Android系统信息(内存、cpu、sd卡、电量、版本)获取
- 34.纯 CSS 创作在文本前后穿梭的边框
- 背水一战 Windows 10 (47) - 控件(ScrollViewer 特性): Chaining, Rail, Inertia, Snap, Zoom
- Windowd系统下Eclipse CDT+MinGW快速搭建C/C++开发环境
- how to use novaclient python api
- 详解MySQL性能优化(二)
- [Swift]八大排序算法(七):归并排序
- JDK原生的HttpURLConnection请求实例
热门文章
- HDU 1018.Big Number-Stirling(斯特林)公式 取N阶乘近似值
- 作妖系列——更改spyder黑色主题
- codevs——1700 施工方案第二季
- mybatis 源码学习(二)sqlsession
- javascript 函数初探 (六)--- 闭包初探#3
- 文件系统之-JAVA Sftp远程操作:
- scheme语言编写执行
- Nginx 第三方模块的安装以及一致性哈希算法的使用
- 《好好说话》zz
- iphone手机连接USB时出现须要Mobile device setup disk上的usbaapl.sys文件