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

首頁 > 語言 > JavaScript > 正文

vue中的inject學習教程

2024-05-06 15:40:13
字體:
供稿:網(wǎng)友

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

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

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

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

    父子組件進行傳參,這時候通常利用props 非父子組件傳參,這時候一般利用vuex

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

所以就有了 provide/inject 進行隔代組件傳遞

父組件

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

對于使用場景,基礎組件應該使用props,我個人覺得一般用于比較復雜業(yè)務,提供基礎數(shù)據(jù),比如最近的基金詳情頁。可以直接在最頂層提供基金的基本信息,然后子組件都可以訪問的到,不用每個單獨提供detail的props 屬性。

PS:vue學習- provide / inject

1、解釋

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

provide 選項應該是:一個對象或返回一個對象的函數(shù)
inject 選項應該是:一個字符串數(shù)組,或 一個對象,對象的 key 是本地的綁定名

2、示例

父組件中提供

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

子組件中引入

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

使用: this.map_nodeObj.map_node

3、運行順序

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

總結(jié)

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 达州市| 吉隆县| 吉首市| 拉萨市| 右玉县| 宁乡县| 攀枝花市| 武冈市| 建昌县| 祁门县| 呼和浩特市| 清新县| 鄯善县| 五常市| 桐乡市| 手游| 湘乡市| 万安县| 巫山县| 七台河市| 鹤壁市| 淮阳县| 鄂伦春自治旗| 台湾省| 合江县| 清镇市| 平和县| 新和县| 潍坊市| 白河县| 麻阳| 永宁县| 大冶市| 合水县| 图们市| 上蔡县| 保山市| 肇州县| 安吉县| 安丘市| 夏河县|