您当前的位置:首页 > 网站建设 > javascript
| php | asp | css | H5 | javascript | Mysql | Dreamweaver | Delphi | 网站维护 | 帝国cms | React | 考试系统 | ajax | jQuery | 小程序 |

vue前端开发层次嵌套组件的通信详解

51自学网 2022-02-21 13:40:09
  javascript

前言

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 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两个关键字完成父组件向子孙组件直接传值,使用起来非常方便。存在问题子组件与父组件存在一种强耦合关系,不再万不得已时不建议使用。

以上就是vue前端开发层次嵌套组件的通信详解的详细内容,更多关于vue层次嵌套组件通信的资料请关注51zixue.net其它相关文章!


下载地址:
vue前端开发keepAlive使用详解
vue前端开发辅助函数状态管理详解示例
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。