Vue组件之间四种通信方式详解

 更新时间:2022年01月10日 15:15:19   作者:℡_牵伴 ※  
vue框架提供了前端开发组件的思想,可以通过组件来组合成一个完整的页面,都是随着组件数量原来越多,组件之间难免需要相互通信。本文将为大家介绍四种组件间的通信方式,需要的可以参考一下

前言

vue 框架提供了前端开发组件的思想,可以通过组件来组合成一个完整的页面,都是随着组件数量原来越多,组件之间难免需要相互通信,那么如何实现组件之间的通信呢?下面介绍 vue 组件通信的几种方法

父子组件通信​

父组件传递 props 给子组件(数据以及改变数据的方法),子组件通过 $emit 来更新父组件的状态

父组件定义,声明状态 { name: 'baidu.com' } 以及可以改变状态的方法update(),通过 name 传递和 @update 把 name 属性和 update 方法传递给子组件

<template>
  <div>
    <Child : @update="update" />
  </div>
</template>

<script>
  import Child from "./components/Child";

  export default {
    name: "App",
    components: {
      Child,
    },
    data() {
      return {
        name: "baidu.com",
      };
    },
    methods: {
      update() {
        this.name = "www.baidu.com";
      },
    },
  };
</script>vue


子组件的定义,定义 props 接收 name 属性,通过 $emit 传递 update 参数通知父组件更新状态

<template>
  <div>
    {{ name }}
    <button @click="$emit('update')">通知父组件数据</button>
  </div>
</template>

<script>
  export default {
    name: "Child",
    props: {
      name: String,
    },
  };
</script>

父组件与子孙组件的通信​

父组件通过 provide 创建对象,子组件通过 inject 来使用父组件的数据,不受组件层级的限制

父组件通过 provide 定义需要传递是数据

<template>
  <div>
    <Child />
  </div>
</template>

<script>
  import Child from "./components/Child";

  export default {
    name: "App",
    components: {
      Child,
    },
    provide: {
      name: "www.baidu.com",
    },
  };
</script>

子组件通过 inject 属性控制哪些属性需要访问

<template>
  <div>{{ name }}</div>
</template>

<script>
  export default {
    name: "Child",
    inject: ["name"],
  };
</script>

父组件获取子组件数据​

通过ref 来获取子组件的实例,可以获取子组件的状态或者调用子组件的方法,例如下面

<template>
  <div>
    <Child ref="child" />
  </div>
</template>

<script>
  import Child from "./components/Child";

  export default {
    name: "App",
    components: {
      Child,
    },
    mounted() {
      console.log(this.$refs.child.title);
    },
  };
</script>

可以通过 this.$refs.child 获取到 Child 组件的实例,访问 Child 组件的 data

无需考虑组件关系的通信​

通过 vue 提供的发布订阅模式,也叫做 EventBus(事件总线)

定义一个 eventBus 实例

import Vue from "vue";
export default new Vue();

父组件在 mounted 生命周期里面通过 $on 监听 update 事件

<template>
  <div>
    <Child : />
  </div>
</template>

<script>
  import Child from "./components/Child";
  import eBus from "../eventBus";

  export default {
    name: "App",
    data() {
      return {
        name: "baidu.com",
      };
    },
    components: {
      Child,
    },
    mounted() {
      eBus.$on("update", (val) => {
        
        this.name = val;
      });
    },
  };
</script>

子组件通过 vue 实例的 $emit 触发 update 事件

<template>
  <div>
    {{ name }}
    <button @click="clickHandle">通知父组件更新</button>
  </div>
</template>

<script>
  import eBus from "../../eventBus";

  export default {
    name: "Child",
    props: {
      name: String,
    },
    data() {
      return {
        title: "child component",
      };
    },
    methods: {
      clickHandle() {
        
        eBus.$emit("update", "Hello World");
      },
    },
  };
</script>

使用全局状态管理库 vuex

具体就不在这里展开讲,有兴趣的可以查阅 vue 官方文档

到此这篇关于Vue组件之间四种通信方式详解的文章就介绍到这了,更多相关Vue组件通信内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

最新评论