层次嵌套组件的通信——vue组件开发(五)

前言

vue父子组件之间通过props很容易的将父组件的值传递给子组件,如果一个组件嵌套很多层,每一层之间度需要同props进行传值,很麻烦,且不易维护。vue通过provide & inject两个关键字完成父组件向子孙组件直接传值,很像子类能够使用父类的属性一样方便。provide & inject一般用于多层之间的传值,两层之间还是使用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 style="border:1px solid orange;color:orange;">
    <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通过provide & inject两个关键字完成父组件向子孙组件直接传值,使用起来非常方便。存在问题子组件与父组件存在一种强耦合关系,不再万不得已时不建议使用。

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值