温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何理解vue前端开发层次嵌套组件的通信

发布时间:2021-10-11 09:27:26 阅读:130 作者:iii 栏目:开发技术
Vue开发者专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

本篇内容主要讲解“如何理解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中数据'
      }
    },
    providefunction() { //注入给子组件属性和方法
      return {
        textthis.msg,
        getMethodfunction() {
          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前端开发层次嵌套组件的通信”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

vue
AI

开发者交流群×