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(插槽通信)
相关推荐
kyriewen5 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒5 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
小林攻城狮6 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦6 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer7 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队7 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY7 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_7 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏7 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
SkyWalking中文站7 小时前
认识 Horizon UI · 1/17:SkyWalking 新一代可观测性控制台
运维·前端·监控