详解Vue实战指南之依赖注入(provide/inject)


Posted in Javascript onNovember 13, 2018

案例

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/#provide-inject
https://cn.vuejs.org/v2/guide/components-edge-cases.html#%E4%BE%9D%E8%B5%96%E6%B3%A8%E5%85%A5

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
GRID拖拽行的实例代码
Jul 18 Javascript
JS画线(实例代码)
Nov 20 Javascript
jQuery中Dom的基本操作小结
Jan 23 Javascript
javascript实现tab响应式切换特效
Jan 29 Javascript
js 上传文件预览的简单实例
Aug 16 Javascript
jquery 实现回车登录详解及实例代码
Oct 23 Javascript
详解基于Node.js的HTTP/2 Server实践
May 31 Javascript
Node错误处理笔记之挖坑系列教程
Jun 05 Javascript
vue中的计算属性实例详解
Sep 19 Javascript
vue slot与传参实例代码讲解
Apr 28 Javascript
layui弹出框Tab选项卡的示例代码
Sep 04 Javascript
JavaScript原生数组函数实例汇总
Oct 14 Javascript
node.js爬取中关村的在线电瓶车信息
Nov 13 #Javascript
详解Vue SSR( Vue2 + Koa2 + Webpack4)配置指南
Nov 13 #Javascript
详解Vue组件插槽的使用以及调用组件内的方法
Nov 13 #Javascript
Vue实现一个无限加载列表功能
Nov 13 #Javascript
Vue实现移动端页面切换效果【推荐】
Nov 13 #Javascript
vue中slot(插槽)的介绍与使用
Nov 12 #Javascript
vuex的module模块用法示例
Nov 12 #Javascript
You might like
JsEasy简介 JsEasy是什么?与下载
2007/03/07 Javascript
用jscript实现新建word文档
2007/06/15 Javascript
理解Javascript_10_对象模型
2010/10/16 Javascript
js 幻灯片的实现
2011/12/06 Javascript
JavaScript实现快速排序(自已编写)
2012/12/19 Javascript
极易被忽视的javascript面试题七问七答
2016/02/15 Javascript
json传值以及ajax接收详解
2016/05/24 Javascript
jquery层级选择器的实现(匹配后代元素div)
2016/09/05 Javascript
关于vue.js弹窗组件的知识点总结
2016/09/11 Javascript
详细总结Javascript中的焦点管理
2016/09/17 Javascript
Bootstrap源码解读网格系统(3)
2016/12/22 Javascript
基于vue的下拉刷新指令和滚动刷新指令
2016/12/23 Javascript
Node.js从字符串生成文件流的实现方法
2019/08/18 Javascript
浅谈JS中几种轻松处理'this'指向方式
2019/09/16 Javascript
[01:02:03]2014 DOTA2华西杯精英邀请赛 5 24 NewBee VS VG
2014/05/26 DOTA
[43:58]DOTA2-DPC中国联赛定级赛 LBZS vs SAG BO3第一场 1月8日
2021/03/11 DOTA
Python基于matplotlib绘制栈式直方图的方法示例
2017/08/09 Python
python3 实现验证码图片切割的方法
2018/12/07 Python
Python 函数list&amp;read&amp;seek详解
2019/08/28 Python
python性能测量工具cProfile使用解析
2019/09/26 Python
Tensorflow读取并输出已保存模型的权重数值方式
2020/01/04 Python
你可能不熟练的十个前端HTML5经典面试题
2018/07/03 HTML / CSS
关于HTML5的安全问题开发人员需要牢记的
2012/06/21 HTML / CSS
巴西24小时在线药房:Droga Raia
2020/05/12 全球购物
公司培训心得体会
2014/01/03 职场文书
2014年教师节寄语
2014/04/03 职场文书
北京离婚协议书范文2014
2014/09/29 职场文书
学校党支部公开承诺书
2015/04/30 职场文书
农贸批发市场管理制度
2015/08/07 职场文书
严以律己专题学习研讨会发言材料
2015/11/09 职场文书
为什么不建议在go项目中使用init()
2021/04/12 Golang
mysql 8.0.24版本安装配置方法图文教程
2021/05/12 MySQL
JavaScript如何优化逻辑判断代码详解
2021/06/08 Javascript
常用的MongoDB查询语句的示例代码
2021/07/25 MongoDB
CSS的calc函数用法小结
2022/06/25 HTML / CSS
webpack介绍使用配置教程详解webpack介绍和使用
2022/06/25 Javascript