UI美眉说咱家的选项菜单太丑了,小哥哥能不能美化一下呀,洒家天然是说小意思啦~
自定义一个select
组件,so easy~javascript
简单粗暴型:html
<el-select v-model="favourite" :option="[]"></el-select>
option
做为数据进来就ok啦。vue
而后发现下列问题:java
key-value
,不是全部的接口都是id-name
option
要disabled
怎么办?option
存在几种状况怎么办?回头看看原生的写法是这样:api
<select v-model="favourite"> <option value="1">Vue</option> <option value="2">React</option> <option value="3">Angular</option> </select>
还要加个el-option
组件,灵活自由型:dom
<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
ide
官方说明:ui
容许一个祖先组件向其全部子孙后代注入一个依赖,不论组件层次有多深(这也是使用
$parent
很差实现的地方),并在起上下游关系成立的时间里始终生效。
不论组件层次有多深,这个简直太爽了,不用再关心dom
层级,只要在祖先组件内部就能够一直使用祖先组件提供的provide
this
下面贴出一部分select
的实现:插件
Object | () => Object
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...