vue3 两个组件之间传值

Props

父组件可以通过 props 将数据传递给子组件。这是最常见的组件间通信方式

html 复制代码
   <!-- 父组件 -->
   <template>
     <ChildComponent :message="parentMessage" />
   </template>

   <script>
   import ChildComponent from './ChildComponent.vue';

   export default {
     components: {
       ChildComponent,
     },
     data() {
       return {
         parentMessage: 'Hello from Parent',
       };
     },
   };
   </script>
html 复制代码
   <!-- 子组件 -->
   <template>
     <div>{{ message }}</div>
   </template>

   <script>
   export default {
     props: {
       message: String,
     },
   };
   </script>

自定义事件 (Emit)

子组件可以通过 $emit 触发事件将数据传递回父组件。

html 复制代码
   <!-- 子组件 -->
   <template>
     <button @click="sendToParent">Send to Parent</button>
   </template>

   <script>
   export default {
     methods: {
       sendToParent() {
         this.$emit('custom-event', 'Hello from Child');
       },
     },
   };
   </script>
html 复制代码
   <!-- 父组件 -->
   <template>
     <ChildComponent @custom-event="handleEvent" />
   </template>

   <script>
   import ChildComponent from './ChildComponent.vue';

   export default {
     components: {
       ChildComponent,
     },
     methods: {
       handleEvent(message) {
         console.log(message);
       },
     },
   };
   </script>

Vuex

Vuex 是 Vue 的状态管理库,可以用来在多个组件间共享状态。

Provide / Inject

这是一种从祖先组件注入数据到后代组件的方式,而无需逐层传递 props。

Ref 和 Reactive

使用 Composition API,可以利用 refs 和 reactive 数据来实现组件间的通信。

Event Bus

虽然在 Vue 3 中,官方推荐使用 Composition API 和其它更现代的通信方式,但在某些情况下,你可能仍然会使用 Event Bus(事件总线)。这通常涉及到创建一个全局事件中心,组件可以通过它发送和接收事件。

javascript 复制代码
   // src/eventBus.js
   import { onMounted, onBeforeUnmount } from 'vue';
   import mitt from 'mitt';

   const eventBus = mitt();

   export default eventBus;
html 复制代码
   <!-- 发送方组件 -->
   <script>
   import eventBus from '@/eventBus';

   export default {
     onMounted() {
       eventBus.on('someEvent', payload => {
         console.log(payload);
       });
     },
     onBeforeUnmount() {
       eventBus.off('someEvent');
     },
     methods: {
       triggerEvent() {
         eventBus.emit('someEvent', 'Hello from Sender');
       },
     },
   };
   </script>

选择哪种方式取决于你的具体需求和组件层次结构。对于简单的父子组件关系,使用 Props 和自定义事件通常就足够了。对于更复杂的场景,如非父子组件之间的通信,Vuex 或者 Event Bus 可能会更加合适。

相关推荐
水银嘻嘻1 小时前
12 web 自动化之基于关键字+数据驱动-反射自动化框架搭建
运维·前端·自动化
it_remember1 小时前
新建一个reactnative 0.72.0的项目
javascript·react native·react.js
小嘟嚷ovo2 小时前
h5,原生html,echarts关系网实现
前端·html·echarts
十一吖i2 小时前
Vue3项目使用ElDrawer后select方法不生效
前端
只可远观2 小时前
Flutter目录结构介绍、入口、Widget、Center组件、Text组件、MaterialApp组件、Scaffold组件
前端·flutter
周胡杰2 小时前
组件导航 (HMRouter)+flutter项目搭建-混合开发+分栏效果
前端·flutter·华为·harmonyos·鸿蒙·鸿蒙系统
敲代码的小吉米2 小时前
前端上传el-upload、原生input本地文件pdf格式(纯前端预览本地文件不走后端接口)
前端·javascript·pdf·状态模式
是千千千熠啊2 小时前
vue使用Fabric和pdfjs完成合同签章及批注
前端·vue.js
da-peng-song3 小时前
ArcGIS Desktop使用入门(二)常用工具条——数据框工具(旋转视图)
开发语言·javascript·arcgis
九月TTS3 小时前
TTS-Web-Vue系列:组件逻辑分离与模块化重构
前端·vue.js·重构