vue3中实现组件通信的方法总结

 更新时间:2023年06月25日 11:39:33   作者:云卷云舒%  
在Vue3中,有多种方法可以实现组件之间的通信,本文就通过代码示例给大家总结一些vue3实现组件通信的常用方法,需要的朋友可以参考下

在 Vue 3 中,有多种方法可以实现组件之间的通信。以下是一些常见的方法:

1、Props 和 Events:父组件通过 props 向子组件传递数据,子组件通过触发事件向父组件发送消息。这是 Vue 中最基本的组件通信方式

props接收的数据是只读的

<!-- 父组件 -->
<template>
  <ChildComponent :message="parentMessage" @childEvent="handleChildEvent" />
</template>
<script setup lang="ts">
import ChildComponent from './ChildComponent.vue';
import {ref} from 'vue'
let parentMessage = ref('Hello from parent'),
const handleChildEvent = (payload) => {
      console.log('Received event from child:', payload);
}
</script>
<!-- 子组件 -->
<template>
  <div>
    <p>{{ props.message }}</p>
    <p>{{ message }}</p>
    <button @click="emitEvent">Send Event to Parent</button>
  </div>
</template>
<script setup lang="ts">
import {defineEmits} from 'vue'
const emit = defineEmits();
// 使用defineProperty来接收数据,defineProperty不需引入直接使用即可defineProps({})或defineProps([]),
// props中的是代理对象,在模板中使用可以省略props,在js中不可省略
const props = defineProps({ message: String});
const emitEvent = () =>{
      $emit('childEvent', 'Hello from child');
}
</script>

2、Provide 和 Inject:这是一种在组件树中跨级传递数据的方法。祖先组件通过 provide 选项提供数据,后代组件通过 inject 选项接收数据。

// 祖先组件
export default {
  provide() {
    return {
      sharedData: 'Shared data from ancestor',
    };
  },
};
// 后代组件
export default {
  inject: ['sharedData'],
};

3、Vuex:Vuex 是一个专门为 Vue.js 应用程序开发的状态管理模式。它可以帮助你管理应用程序中的共享状态,实现组件之间的通信。

首先,你需要安装 Vuex 并在你的应用程序中配置它:

npm install vuex@next --save

然后,创建一个 Vuex store:

// store.js
import { createStore } from 'vuex';
export default createStore({
  state: {
    count: 0,
  },
  mutations: {
    increment(state) {
      state.count++;
    },
  },
});

在你的应用程序中使用 store:

// main.js
import { createApp } from 'vue';
import App from './App.vue';
import store from './store';
createApp(App).use(store).mount('#app');

现在,你可以在组件中使用 this.$store 访问 store,并通过提交 mutation 或 dispatching action 来更新状态。

<!-- 组件 -->
<template>
  <div>
    <p>{{ $store.state.count }}</p>
    <button @click="$store.commit('increment')">Increment</button>
  </div>
</template>

这些方法可以根据你的需求和应用程序的复杂性来选择。对于简单的组件通信,Props 和 Events 通常就足够了。对于更复杂的应用程序,你可能需要考虑使用 Provide/Inject 或 Vuex。

4、类似vue2中的eventBus插件mitt 实现全局通信

到此这篇关于vue3中实现组件通信的方法总结的文章就介绍到这了,更多相关vue3组件通信内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue使用微信扫一扫功能的实现代码

    vue使用微信扫一扫功能的实现代码

    这篇文章主要介绍了vue使用微信扫一扫功能的实现代码,需要的朋友可以参考下
    2020-04-04
  • 解决vue单页面 回退页面 keeplive 缓存问题

    解决vue单页面 回退页面 keeplive 缓存问题

    这篇文章主要介绍了解决vue单页面 回退页面 keeplive 缓存问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • vue3二次封装element-ui中的table组件的过程详解

    vue3二次封装element-ui中的table组件的过程详解

    这篇文章主要给大家介绍了vue3二次封装element-ui中的table组件的过程,文中通过代码示例给大家介绍的非常详细,对大家的学习或工作有一定的帮助,需要的朋友跟着小编一起来学习吧
    2024-01-01
  • vue滚动固定顶部及修改样式的实例代码

    vue滚动固定顶部及修改样式的实例代码

    这篇文章主要介绍了vue滚动固定顶部及修改样式,本文给大家提到了滚动固定位置有多种方法,感兴趣的朋友跟随小编一起看看吧
    2019-05-05
  • vue实现扫码功能

    vue实现扫码功能

    这篇文章主要为大家详细介绍了vue实现扫码功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-01-01
  • Vue组件开发之异步组件详解

    Vue组件开发之异步组件详解

    这篇文章主要为大家详细介绍了Vue组件开发之异步组件,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • vue项目里面引用svg文件并给svg里面的元素赋值

    vue项目里面引用svg文件并给svg里面的元素赋值

    这篇文章主要介绍了vue项目里面引用svg文件并给svg里面的元素赋值,本文分步骤通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • Vue高级组件之函数式组件的使用场景与源码分析

    Vue高级组件之函数式组件的使用场景与源码分析

    Vue提供了一种称为函数式组件的组件类型,用来定义那些没有响应数据,也不需要有任何生命周期的场景,它只接受一些props来显示组件,下面这篇文章主要给大家介绍了关于Vue高级组件之函数式组件的使用场景与源码分析的相关资料,需要的朋友可以参考下
    2021-11-11
  • vue实现仿淘宝结账页面实例代码

    vue实现仿淘宝结账页面实例代码

    本文是小编给大家分享的vue实现仿淘宝结账页面实例代码,主要功能是仿照淘宝页面的结算购物车商品时自动算出合计价格的页面,具体实例代码大家参考下本文
    2017-11-11
  • 前端vue面试总问watch和computed区别及建议总结

    前端vue面试总问watch和computed区别及建议总结

    在现代前端的面试中,vue和react是面试过程中基本必问的技术栈,其中Vue响应式话题,watch和computed是面试官非常喜欢聊的主题,虽然watch和computed它们都用于监听数据的变化,但它们在实现原理、使用场景和行为上有着显著的区别,本文将深入探讨,并提供一些面试过程中的建议
    2023-10-10

最新评论