詳解Vue實(shí)戰(zhàn)指南之依賴注入(provide/inject)
案例
UI美眉說咱家的選項(xiàng)菜單太丑了,小哥哥能不能美化一下呀,灑家自然是說小意思啦~
自定義一個(gè)select組件,so easy~
簡(jiǎn)單粗暴型:
<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>
還要加個(gè)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è)計(jì)就能完美解決之前的幾個(gè)問題。
接著要解決選擇了某一個(gè)el-option,怎么告訴el-select,$parent是一種選擇,那么el-select當(dāng)前的值又怎么告訴el-option你被選中了呢~ 筆者沒有繼續(xù)去深究,因?yàn)榭吹搅薃PIprovide/inject
官方說明:
允許一個(gè)祖先組件向其所有子孫后代注入一個(gè)依賴,不論組件層次有多深(這也是使用$parent不好實(shí)現(xiàn)的地方),并在起上下游關(guān)系成立的時(shí)間里始終生效。
不論組件層次有多深,這個(gè)簡(jiǎn)直太爽了,不用再關(guān)心dom層級(jí),只要在祖先組件內(nèi)部就可以一直使用祖先組件提供的provide
用法
下面貼出一部分select的實(shí)現(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 是解決組件之間的通信問題的利器,不受層級(jí)結(jié)構(gòu)的限制。
但也不是隨便去濫用,通信代表著耦合:
provide 和 inject 主要為高階插件/組件庫(kù)提供用例。并不推薦直接用于應(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
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue組件中點(diǎn)擊按鈕后修改輸入框的狀態(tài)實(shí)例代碼
要求點(diǎn)擊修改按鈕之后部分輸入框由禁用狀態(tài)變?yōu)榭捎脿顟B(tài)。下面我給大家分享一段實(shí)例代碼基于vue組件中點(diǎn)擊按鈕后修改輸入框的狀態(tài),需要的的朋友參考下2017-04-04五分鐘教你使用vue-cli3創(chuàng)建項(xiàng)目(新手入門)
本文主要介紹了五分鐘教你使用vue-cli3創(chuàng)建項(xiàng)目,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09vue3.0實(shí)現(xiàn)點(diǎn)擊切換驗(yàn)證碼(組件)及校驗(yàn)
這篇文章主要為大家詳細(xì)介紹了vue3.0實(shí)現(xiàn)點(diǎn)擊切換驗(yàn)證碼(組件)及校驗(yàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11vue中接口域名配置為全局變量的實(shí)現(xiàn)方法
今天小編就為大家分享一篇vue中接口域名配置為全局變量的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09關(guān)于應(yīng)用UI組件的移動(dòng)端適配方式
這篇文章主要介紹了關(guān)于應(yīng)用UI組件的移動(dòng)端適配方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09Vue項(xiàng)目部署后首頁(yè)白屏問題排查與解決方法
在部署 Vue.js 項(xiàng)目時(shí),有時(shí)會(huì)遇到首頁(yè)加載后出現(xiàn)白屏的情況,這可能是由于多種原因造成的,本文將介紹一些常見的排查方法和解決方案,幫助開發(fā)者快速定位問題并解決,感興趣的小伙伴跟著小編一起來看看吧2024-08-08vue+axios全局添加請(qǐng)求頭和參數(shù)操作
這篇文章主要介紹了vue+axios全局添加請(qǐng)求頭和參數(shù)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07vue父元素點(diǎn)擊事件與子元素點(diǎn)擊事件沖突問題
這篇文章主要介紹了vue父元素點(diǎn)擊事件與子元素點(diǎn)擊事件沖突問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01