欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue中的inject學(xué)習(xí)教程

 更新時(shí)間:2019年04月24日 11:59:55   作者:無雪冬天  
本文通過實(shí)例代碼給大家介紹了vue中的inject學(xué)習(xí)教程,非常不錯,具有一定的參考借鑒價(jià)值,需要的朋友參考下吧

最近看源碼有一段對于整合參數(shù)的代碼,

normalizeProps(child, vm)
 normalizeInject(child, vm)
 normalizeDirectives(child)

想象里邊的Inject很少用到,所以查了一下資料,

通常組件傳參是有兩種情況

  1. 父子組件進(jìn)行傳參,這時(shí)候通常利用props
  2. 非父子組件傳參,這時(shí)候一般利用vuex

會有一種情況隔代組件傳參,這時(shí)候可以利用props一層一層傳遞下去,但是代碼就比較亂了

所以就有了 provide/inject 進(jìn)行隔代組件傳遞

父組件

<template>
  <div class="test">
    <son></son>
  </div>
</template>
<script>
export default {
  name: 'Test',
  provide: {
    name: 'Garrett'
  }
}
</script>

子組件

<template>
  <div>
    {{name}}
  </div>
</template>
 
<script>
export default {
  name: 'Garrettson',
  inject: [name]
}
</script>

對于使用場景,基礎(chǔ)組件應(yīng)該使用props,我個(gè)人覺得一般用于比較復(fù)雜業(yè)務(wù),提供基礎(chǔ)數(shù)據(jù),比如最近的基金詳情頁??梢灾苯釉谧铐攲犹峁┗鸬幕拘畔ⅲ缓笞咏M件都可以訪問的到,不用每個(gè)單獨(dú)提供detail的props 屬性。

PS:vue學(xué)習(xí)- provide / inject

1、解釋

provide / inject這對選項(xiàng)需要一起使用,以允許一個(gè)祖先組件向其所有子孫后代注入一個(gè)依賴,不論組件層次有多深,并在起上下游關(guān)系成立的時(shí)間里始終生效。

provide 選項(xiàng)應(yīng)該是:一個(gè)對象或返回一個(gè)對象的函數(shù)
inject 選項(xiàng)應(yīng)該是:一個(gè)字符串?dāng)?shù)組,或 一個(gè)對象,對象的 key 是本地的綁定名

2、示例

父組件中提供

 provide() {
  return {
   map_nodeObj: { map_node: this.obj }
   // 提示:provide 和 inject 綁定并不是可響應(yīng)的。這是刻意為之的。然而,如果你傳入了一個(gè)可監(jiān)聽的對象,那么其對象的屬性還是可響應(yīng)的。
  }
 },

子組件中引入

 inject: {
  map_nodeObj: {
   default: () => {
    return {map_node: '0'}
   }
  }
 },

使用: this.map_nodeObj.map_node

3、運(yùn)行順序

data
provide
created // 在這個(gè)階段$el還未生成,在這先處理privide的邏輯,子孫組件才可以取到inject的值
mounted
...

總結(jié)

以上所述是小編給大家介紹的vue中的inject學(xué)習(xí)教程,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

最新評論