詳解Vue實戰(zhàn)指南之依賴注入(provide/inject)
案例
UI美眉說咱家的選項菜單太丑了,小哥哥能不能美化一下呀,灑家自然是說小意思啦~
自定義一個select組件,so easy~
簡單粗暴型:
<el-select v-model="favourite" :option="[]"></el-select>
option作為數(shù)據(jù)進(jìn)來就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
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
聊聊vue生命周期鉤子函數(shù)有哪些,分別什么時候觸發(fā)
這篇文章主要介紹了聊聊vue生命周期鉤子函數(shù)有哪些,分別什么時候觸發(fā)?具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04
詳解webpack打包vue項目之后生成的dist文件該怎么啟動運行
這篇文章主要介紹了詳解webpack打包vue項目之后生成的dist文件該怎么啟動運行,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
關(guān)于Vue項目使用scss終端發(fā)出警告解決方法
這篇文章主要介紹了關(guān)于Vue項目使用scss終端發(fā)出警告的解決方法,出現(xiàn)這個問題的原因是項目中使用了DartSass舊版的JavaScriptAPI,這些API已被棄用,文章將解決的辦法介紹的非常詳細(xì),需要的朋友可以參考下2025-04-04
使用Webstorm調(diào)試Vue代碼詳細(xì)圖文教程
WebStorm是一款優(yōu)秀的前端開發(fā)IDE,之前一直可以調(diào)試Vue項目,下面這篇文章主要給大家介紹了關(guān)于使用Webstorm調(diào)試Vue代碼的詳細(xì)圖文教程,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2024-05-05

