Vue 3 常见的通信方式

在 Vue 3 中,组件通信方式更丰富、语法更现代化,旧的方式也有一些优化或替代。下面是 Vue 3 常见的通信方式,按使用场景来整理:


✅ 一、父子组件通信

1. props(父传子)

复制代码
<!-- 父组件 -->
<Child :msg="msgFromParent" />

<!-- 子组件 -->
defineProps(['msg'])

2. $emit(子传父)

复制代码
<!-- 子组件 -->
const emit = defineEmits(['update'])
emit('update', value)

<!-- 父组件 -->
<Child @update="handleUpdate" />

✅ 二、兄弟组件通信(非父子)

3. 使用第三方事件总线(推荐 mitt

复制代码
npm install mitt

// eventBus.ts
import mitt from 'mitt'
export const emitter = mitt()

// A组件发送
emitter.emit('eventName', data)

// B组件接收
emitter.on('eventName', (data) => { ... })

✅ 三、跨层级通信

4. provide / inject

适合祖先 -> 任意后代组件传值

复制代码
// 父组件
provide('theme', 'dark')

// 子组件
const theme = inject('theme')

✅ 四、全局状态管理(跨组件、跨页面通信)

5. 使用 Pinia(官方推荐,Vuex 5 已转型)

复制代码
npm install pinia

// store/counter.ts
import { defineStore } from 'pinia'
export const useCounterStore = defineStore('counter', {
  state: () => ({ count: 0 }),
  actions: { increment() { this.count++ } },
})

// 在组件中
const counter = useCounterStore()
counter.increment()

✅ 五、ref & expose(父调子组件的方法)

6. ref + defineExpose

复制代码
<!-- 子组件 -->
<script setup>
function sayHello() { console.log('hello') }
defineExpose({ sayHello })
</script>

<!-- 父组件 -->
<Child ref="childRef" />
<script setup>
const childRef = ref()
onMounted(() => {
  childRef.value.sayHello()
})
</script>

✅ 六、路由参数传值

7. 使用 vue-routerparamsquery

复制代码
// 传值
router.push({ name: 'User', params: { id: 123 } })
router.push({ path: '/user', query: { id: 123 } })

// 接收
const route = useRoute()
console.log(route.params.id)
console.log(route.query.id)

✅ 七、LocalStorage / SessionStorage(跨页面通信)

虽然不是组件通信的正统方式,但用于跨页保留状态还是常见:

复制代码
localStorage.setItem('token', 'xxx')
const token = localStorage.getItem('token')
相关推荐
宋辰月6 分钟前
Vue2-VueRouter
开发语言·前端·javascript
haaaaaaarry1 小时前
Element Plus常见基础组件(一)
java·前端·javascript·vue.js
萌萌哒草头将军2 小时前
Prisma ORM 又双叒叕发布新版本了!🚀🚀🚀
前端·javascript·node.js
mldong2 小时前
推荐一款超高颜值的后台管理模板!Art-Design-Pro!开源!免费!
前端·vue.js·架构
我是ed.2 小时前
cocos Js 使用 webview 通过 postMessage 进行通信
开发语言·javascript·ecmascript
脑袋大大的4 小时前
uni-app x开发避坑指南:拯救被卡顿的UI线程!
开发语言·前端·javascript·vue.js·ui·uni-app·uts
前端Hardy4 小时前
10 分钟搞定婚礼小程序?我用 DeepSeek 把同学的作业卷成了范本!
前端·javascript·微信小程序
Tminihu4 小时前
前端大文件上传的时候,采用切片上传的方式,如果断网了,应该如何处理
前端·javascript
颜酱4 小时前
理解vue3中的compiler-core
前端·javascript·vue.js
果粒chenl4 小时前
06-原型和原型链
前端·javascript·原型模式