這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)如何在vue中使用inject,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
創(chuàng)新互聯(lián)公司是一家專業(yè)提供彌渡企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站制作、網(wǎng)站設(shè)計、HTML5建站、小程序制作等業(yè)務(wù)。10年已為彌渡眾多企業(yè)、政府機構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站設(shè)計公司優(yōu)惠進行中。
最近看源碼有一段對于整合參數(shù)的代碼,
normalizeProps(child, vm) normalizeInject(child, vm) normalizeDirectives(child)
想象里邊的Inject很少用到,所以查了一下資料,
通常組件傳參是有兩種情況
父子組件進行傳參,這時候通常利用props
非父子組件傳參,這時候一般利用vuex
會有一種情況隔代組件傳參,這時候可以利用props一層一層傳遞下去,但是代碼就比較亂了
所以就有了 provide/inject
進行隔代組件傳遞
父組件
子組件
{{name}}
對于使用場景,基礎(chǔ)組件應(yīng)該使用props,我個人覺得一般用于比較復(fù)雜業(yè)務(wù),提供基礎(chǔ)數(shù)據(jù),比如最近的基金詳情頁??梢灾苯釉谧铐攲犹峁┗鸬幕拘畔ⅲ缓笞咏M件都可以訪問的到,不用每個單獨提供detail的props 屬性。
PS:vue學(xué)習(xí)- provide / inject
1、解釋
provide / inject這對選項需要一起使用,以允許一個祖先組件向其所有子孫后代注入一個依賴,不論組件層次有多深,并在起上下游關(guān)系成立的時間里始終生效。
provide 選項應(yīng)該是:一個對象或返回一個對象的函數(shù)
inject 選項應(yīng)該是:一個字符串?dāng)?shù)組,或 一個對象,對象的 key 是本地的綁定名
2、示例
父組件中提供
provide() { return { map_nodeObj: { map_node: this.obj } // 提示:provide 和 inject 綁定并不是可響應(yīng)的。這是刻意為之的。然而,如果你傳入了一個可監(jiān)聽的對象,那么其對象的屬性還是可響應(yīng)的。 } },
子組件中引入
inject: { map_nodeObj: { default: () => { return {map_node: '0'} } } },
使用: this.map_nodeObj.map_node
3、運行順序
data provide created // 在這個階段$el還未生成,在這先處理privide的邏輯,子孫組件才可以取到inject的值 mounted ...
上述就是小編為大家分享的如何在vue中使用inject了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。