亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解Vue實(shí)戰(zhàn)指南之依賴注入(provide/inject)

 更新時(shí)間:2018年11月13日 09:49:30   作者:Chendye  
這篇文章主要介紹了詳解Vue實(shí)戰(zhàn)指南之依賴注入(provide/inject),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

案例

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)文章

最新評(píng)論