案例
UI美眉說咱家的選項菜單太丑了华匾,小哥哥能不能美化一下呀,灑家自然是說小意思啦~
自定義一個select
組件浅侨,so easy~
簡單粗暴型:
<el-select v-model="favourite" :option="[]"></el-select>
option
作為數(shù)據(jù)進來就ok啦纽谒。
然后發(fā)現(xiàn)下列問題:
-
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>
好啦挨决,這樣設(shè)計就能完美解決之前的幾個問題。
接著要解決選擇了某一個el-option
订歪,怎么告訴el-select
脖祈,$parent
是一種選擇,那么el-select
當(dāng)前的值又怎么告訴el-option
你被選中了呢~ 筆者沒有繼續(xù)去深究刷晋,因為看到了APIprovide/inject
官方說明:
允許一個祖先組件向其所有子孫后代注入一個依賴盖高,不論組件層次有多深(這也是使用
$parent
不好實現(xiàn)的地方)慎陵,并在起上下游關(guān)系成立的時間里始終生效。
不論組件層次有多深喻奥,這個簡直太爽了席纽,不用再關(guān)心dom
層級,只要在祖先組件內(nèi)部就可以一直使用祖先組件提供的provide
用法
下面貼出一部分select
的實現(xiàn):
-
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;
}
}
}
總結(jié)
provide/inject
是解決組件之間的通信問題的利器撞蚕,不受層級結(jié)構(gòu)的限制润梯。
但也不是隨便去濫用,通信代表著耦合:
provide
和inject
主要為高階插件/組件庫提供用例甥厦。并不推薦直接用于應(yīng)用程序代碼中纺铭。
官方文檔:
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