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...