Vue组件通信方式?

一、父子组件通信(最常用)

1. props(父 → 子)

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

父组件

xml 复制代码
<template>
  <Child :title="msg" />
</template>

<script>
import Child from './Child.vue'

export default {
  components: { Child },
  data() {
    return {
      msg: 'Hello Vue'
    }
  }
}
</script>

子组件

xml 复制代码
<script>
export default {
  props: ['title']
}
</script>

子组件可以直接使用 title


2. $emit(子 → 父)

子组件通过 $emit 触发事件通知父组件。

子组件

xml 复制代码
<template>
  <button @click="send">点击</button>
</template>

<script>
export default {
  methods: {
    send() {
      this.$emit('update', '来自子组件的数据')
    }
  }
}
</script>

父组件

scss 复制代码
<Child @update="getData" />

methods:{
  getData(val){
    console.log(val)
  }
}

二、父子组件通信(高级)

3. ref(父直接调用子)

父组件通过 ref 获取子组件实例。

ini 复制代码
<Child ref="childRef" />
kotlin 复制代码
this.$refs.childRef.childMethod()

适合:

  • 调用子组件方法
  • 获取子组件数据

4. provide / inject(跨层级)

适合 祖先 → 后代组件

祖组件

javascript 复制代码
provide() {
  return {
    theme: 'dark'
  }
}

子孙组件

vbnet 复制代码
inject: ['theme']

三、兄弟组件通信

5. EventBus(Vue2常用)

创建一个事件总线。

javascript 复制代码
// bus.js
import Vue from 'vue'
export default new Vue()

发送

bash 复制代码
bus.$emit('sendMsg', data)

接收

javascript 复制代码
bus.$on('sendMsg', (data)=>{
  console.log(data)
})

⚠️ Vue3 不推荐。


四、全局状态管理

6. Vuex(大型项目)

Vuex 中统一管理状态。

css 复制代码
组件A → commit → store → 组件B

示例:

kotlin 复制代码
this.$store.commit('setUser', data)

读取:

kotlin 复制代码
this.$store.state.user

7. Pinia(Vue3 推荐)

Pinia 是 Vue3 官方推荐状态管理。

ini 复制代码
const store = useUserStore()

store.name = '张三'

任何组件都可以直接使用。


五、插槽通信

8. slot / scoped slot

父组件向子组件传入结构,子组件向父组件返回数据。

xml 复制代码
<Child>
  <template #default="scope">
    {{ scope.data }}
  </template>
</Child>

六、总结(面试高频)

通信方式 场景
props 父 → 子
$emit 子 → 父
ref 父调用子方法
provide/inject 跨层级
EventBus 兄弟组件
Vuex / Pinia 全局状态
slot 组件复用

💡 面试标准回答(简洁版):

Vue组件通信主要有:

  1. props / emit(父子通信)
  2. ref(父调用子)
  3. provide / inject(跨层级)
  4. EventBus(兄弟组件)
  5. Vuex / Pinia(全局状态管理)
  6. slot(插槽通信)
相关推荐
布局呆星21 分钟前
Vue3 计算属性|从基础缓存到可读写
前端·javascript·vue.js
ZPC82108 小时前
如何创建一个单例类 (Singleton)
开发语言·前端·人工智能
紫_龙8 小时前
最新版vue3+TypeScript开发入门到实战教程之重要详解readonly/shallowReadOnly
前端·javascript·typescript
roamingcode9 小时前
前端 AI Agent 多智能体协作架构:从对抗式排查到工作流解耦
前端·人工智能·架构·agent·team
蓝莓味的口香糖10 小时前
【vue】初始化 Vue 项目
前端·javascript·vue.js
光影少年11 小时前
数组去重方法
开发语言·前端·javascript
我命由我1234511 小时前
浏览器的 JS 模块化支持观察记录
开发语言·前端·javascript·css·html·ecmascript·html5
weixin_4434785111 小时前
Flutter第三方常用组件包之路由管理
前端·javascript·flutter
武藤一雄11 小时前
C# 异步回调与等待机制
前端·microsoft·设计模式·微软·c#·.netcore
啥都不懂的小小白12 小时前
前端CSS入门详解
前端·css