国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

詳解Vue實戰指南之依賴注入(provide/inject)

2019-11-19 12:31:50
字體:
來源:轉載
供稿:網友

案例

UI美眉說咱家的選項菜單太丑了,小哥哥能不能美化一下呀,灑家自然是說小意思啦~

自定義一個select組件,so easy~

簡單粗暴型:

<el-select v-model="favourite" :option="[]"></el-select>

option作為數據進來就ok啦。

然后發現下列問題:

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

好啦,這樣設計就能完美解決之前的幾個問題。

接著要解決選擇了某一個el-option,怎么告訴el-select,$parent是一種選擇,那么el-select當前的值又怎么告訴el-option你被選中了呢~ 筆者沒有繼續去深究,因為看到了APIprovide/inject

官方說明:

允許一個祖先組件向其所有子孫后代注入一個依賴,不論組件層次有多深(這也是使用$parent不好實現的地方),并在起上下游關系成立的時間里始終生效。
不論組件層次有多深,這個簡直太爽了,不用再關心dom層級,只要在祖先組件內部就可以一直使用祖先組件提供的provide

用法

下面貼出一部分select的實現:

  • 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; } }}

總結

provide/inject 是解決組件之間的通信問題的利器,不受層級結構的限制。

但也不是隨便去濫用,通信代表著耦合:

provide 和 inject 主要為高階插件/組件庫提供用例。并不推薦直接用于應用程序代碼中。

官方文檔:

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 通渭县| 察雅县| 寻甸| 曲麻莱县| 龙里县| 离岛区| 余姚市| 钟祥市| 南城县| 白河县| 东台市| 平度市| 蓝田县| 锡林郭勒盟| 房产| 额济纳旗| 阳高县| 兰坪| 陆丰市| 汉源县| 甘南县| 霍州市| 宜兰市| 宝兴县| 乌拉特中旗| 滕州市| 衡山县| 宁蒗| 长宁区| 湖北省| 昌吉市| 磐安县| 罗田县| 南昌市| 张家港市| 万载县| 正蓝旗| 大竹县| 九台市| 太仓市| 贵溪市|