91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何理解vue前端開發層次嵌套組件的通信

發布時間:2021-10-11 09:27:26 來源:億速云 閱讀:121 作者:iii 欄目:開發技術

本篇內容主要講解“如何理解vue前端開發層次嵌套組件的通信”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何理解vue前端開發層次嵌套組件的通信”吧!

目錄
  • 前言

  • 示例

  • 小結

前言

vue父子組件之間通過props很容易的將父組件的值傳遞給子組件,如果一個組件嵌套很多層,每一層之間度需要同props進行傳值,很麻煩,且不易維護

示例

【示例】A組件中使用了B組件,B組件中使用了C組件,C組件需要使用A組件的數據text及使用A組件的方法getmethod。A組件代碼如下:

<template>
  <div>
    <P>這是A組件</P>
    <v-comb></v-comb>
  </div>
</template>
<script>
  import comB from '@/view/comB.vue'
  export default {
    name: 'comA',
    components: {
      'v-comb': comB
    },
    data() {
      return {
        msg: '我是組件A中數據'
      }
    },
    provide: function() { //注入給子組件屬性和方法
      return {
        text: this.msg,
        getMethod: function() {
          console.log('執行根組件中的getMethod方法')
        }
      }
    }
  }
</script>

使用關鍵字provide,將數據和方法暴露給子組件
B組件是A組件子組件,是C組件的父組件,代碼如下

<template>
  <div>
    <div>
      <P>這是B組件</P>
      <v-comc></v-comc>
    </div>
  </div>
</template>
<script>
  import comC from '@/view/comC.vue'
  export default {
    name: 'comB',
    components: {
      'v-comc': comC
    }
  }
</script>

C組件是A組件的孫子組件,C組件需要使用A組件的數據和方法,代碼如下:

<template>
  <div >
    <div>
      <P>這是C組件</P>
      <div>{{text}}</div>
      <button @click="getMethod">調用父組件方法</button>
    </div>
  </div>
</template>
<script>
  export default {
    name: 'comC',
    inject: ['text', 'getMethod'] //text和getMethod是provide提供的名字
  }
</script>

這里使用inject關鍵字,接收A組件暴露的信息,這里特別注意, inject: []中接收名字必須與provide提供的名字完全一致。

運行,界面如下圖所示

如何理解vue前端開發層次嵌套組件的通信

小結

多層次組件嵌套通信,vue通過provide & inject兩個關鍵字完成父組件向子孫組件直接傳值,使用起來非常方便。存在問題子組件與父組件存在一種強耦合關系,不再萬不得已時不建議使用。

到此,相信大家對“如何理解vue前端開發層次嵌套組件的通信”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

平乡县| 贵南县| 乐平市| 定远县| 峨眉山市| 萨迦县| 巴东县| 阿荣旗| 墨竹工卡县| 奎屯市| 衡南县| 大港区| 丰城市| 东兴市| 图木舒克市| 方城县| 大兴区| 杭锦后旗| 福泉市| 两当县| 图木舒克市| 萍乡市| 广饶县| 宜阳县| 新蔡县| 虎林市| 甘孜| 鄂温| 台江县| 卢氏县| 海兴县| 尼勒克县| 玛纳斯县| 增城市| 沁源县| 格尔木市| 巴楚县| 古丈县| 兴化市| 陵川县| 大田县|