Vue 组件之间的通信

在 Vue.js 中,组件是构建应用程序的基本单位。然而,当你的应用程序变得复杂时,组件之间的通信变得至关重要。本文将介绍几种 Vue 组件之间通信的方式,帮助你更好地管理和组织代码。

父子组件通信

父组件可以通过 props 向子组件传递数据,子组件则可以通过 $emit 向父组件发送事件。

通过 props 传递数据

父组件通过 props 向子组件传递数据:

<!-- 父组件 -->
<template>
  <div>
    <child-component :message="parentMessage"></child-component>
  </div>
</template>

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

export default {
  components: {
    ChildComponent
  },
  data() {
    return {
      parentMessage: 'Hello from Parent!'
    };
  }
};
</script>

子组件通过 props 接收数据:

<!-- 子组件 -->
<template>
  <div>
    <p>{{ message }}</p>
  </div>
</template>

<script>
export default {
  props: ['message']
};
</script>
通过 $emit 发送事件

子组件通过 $emit 向父组件发送事件:

<!-- 子组件 -->
<template>
  <div>
    <button @click="sendMessage">Send Message</button>
  </div>
</template>

<script>
export default {
  methods: {
    sendMessage() {
      this.$emit('message-sent', 'Hello from Child!');
    }
  }
};
</script>

父组件监听子组件的事件:

<!-- 父组件 -->
<template>
  <div>
    <child-component @message-sent="handleMessage"></child-component>
  </div>
</template>

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

export default {
  components: {
    ChildComponent
  },
  methods: {
    handleMessage(message) {
      console.log(message);  // 输出 'Hello from Child!'
    }
  }
};
</script>
兄弟组件通信

兄弟组件之间通常通过事件总线(Event Bus)或 Vuex 状态管理来实现通信。

使用事件总线

创建一个事件总线:

// event-bus.js
import Vue from 'vue';
export const EventBus = new Vue();

在兄弟组件中使用事件总线:

<!-- 组件 A -->
<template>
  <div>
    <button @click="sendMessage">Send Message</button>
  </div>
</template>

<script>
import { EventBus } from './event-bus.js';

export default {
  methods: {
    sendMessage() {
      EventBus.$emit('message-sent', 'Hello from Component A!');
    }
  }
};
</script>
<!-- 组件 B -->
<template>
  <div>
    <p>{{ message }}</p>
  </div>
</template>

<script>
import { EventBus } from './event-bus.js';

export default {
  data() {
    return {
      message: ''
    };
  },
  created() {
    EventBus.$on('message-sent', (message) => {
      this.message = message;
    });
  }
};
</script>
使用 Vuex

使用 Vuex 是管理应用程序状态的最佳实践。首先安装并配置 Vuex:

// store.js
import Vue from 'vue';
import Vuex from 'vuex';

Vue.use(Vuex);

export default new Vuex.Store({
  state: {
    message: ''
  },
  mutations: {
    setMessage(state, message) {
      state.message = message;
    }
  },
  actions: {
    updateMessage({ commit }, message) {
      commit('setMessage', message);
    }
  }
});

在组件中使用 Vuex:

<!-- 组件 A -->
<template>
  <div>
    <button @click="sendMessage">Send Message</button>
  </div>
</template>

<script>
export default {
  methods: {
    sendMessage() {
      this.$store.dispatch('updateMessage', 'Hello from Component A!');
    }
  }
};
</script>

<!-- 组件 B -->
<template>
  <div>
    <p>{{ message }}</p>
  </div>
</template>

<script>
export default {
  computed: {
    message() {
      return this.$store.state.message;
    }
  }
};
</script>
父子组件通信与兄弟组件通信总结

理解 Vue 组件之间的通信是开发复杂应用程序的关键。通过 props$emit 进行父子组件通信,以及使用事件总线或 Vuex 进行兄弟组件通信,你可以更有效地管理和组织代码。

相关推荐

  1. vue 之间通信方式

    2024-06-07 13:34:03       66 阅读
  2. Vue 之间通信

    2024-06-07 13:34:03       34 阅读
  3. Vue 之间通信方式

    2024-06-07 13:34:03       30 阅读
  4. vue之间通信方式有哪些

    2024-06-07 13:34:03       27 阅读
  5. vue之间通信方式

    2024-06-07 13:34:03       48 阅读
  6. vue2面试题:vue之间通信方式有哪些?

    2024-06-07 13:34:03       48 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-07 13:34:03       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-07 13:34:03       106 阅读
  3. 在Django里面运行非项目文件

    2024-06-07 13:34:03       87 阅读
  4. Python语言-面向对象

    2024-06-07 13:34:03       96 阅读

热门阅读

  1. 连续分配存储管理方式

    2024-06-07 13:34:03       21 阅读
  2. C++实现图像的模拟运动模糊

    2024-06-07 13:34:03       23 阅读
  3. 1103. 分糖果 II

    2024-06-07 13:34:03       27 阅读
  4. 力扣每日一题 6/7

    2024-06-07 13:34:03       35 阅读
  5. input 输入框只能输入数字的处理方式

    2024-06-07 13:34:03       26 阅读
  6. shujugeshi

    2024-06-07 13:34:03       23 阅读
  7. linux系统使用达梦数据库

    2024-06-07 13:34:03       27 阅读
  8. Stream流

    Stream流

    2024-06-07 13:34:03      18 阅读
  9. 图像压缩方案比较

    2024-06-07 13:34:03       26 阅读
  10. OpenHarmony及鸿蒙应用的屏幕亮度获取以及设置

    2024-06-07 13:34:03       26 阅读
  11. 设计模式—状态模式

    2024-06-07 13:34:03       29 阅读