没有合适的资源?快使用搜索试试~ 我知道了~
首页详解Vue实战指南之依赖注入(provide/inject)
案例 UI美眉说咱家的选项菜单太丑了,小哥哥能不能美化一下呀,洒家自然是说小意思啦~ 自定义一个select组件,so easy~ 简单粗暴型: <el v-model=favourite option=[]></el> option作为数据进来就ok啦。 然后发现下列问题: key-value,不是所有的接口都是id-name option要disabled 怎么办? option存在几种情况怎么办? … 回头看看原生的写法是这样: <select v-model=favourite> <option value=1>V
资源详情
资源评论
资源推荐

详解详解Vue实战指南之依赖注入实战指南之依赖注入(provide/inject)
案例案例
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',


















安全验证
文档复制为VIP权益,开通VIP直接复制

评论0