vue3 兄弟组件通信
时间: 2023-07-19 10:46:28 浏览: 95
在 Vue3 中,可以使用 `provide` 和 `inject` 实现兄弟组件之间的通信。
具体地,兄弟组件之间的通信需要一个共同的父组件,父组件中使用 `provide` 方法提供一个属性或方法,然后兄弟组件中使用 `inject` 方法注入该属性或方法,就可以实现通信了。
下面是一个示例代码:
```html
<template>
<div>
<child-a />
<child-b />
</div>
</template>
<script>
import { provide, ref } from 'vue'
import ChildA from './ChildA.vue'
import ChildB from './ChildB.vue'
export default {
components: {
ChildA,
ChildB
},
setup() {
const message = ref('Hello, world!')
provide('message', message) // 提供共享数据
return {
message
}
}
}
</script>
```
在上面的代码中,父组件通过 `provide` 方法提供了一个名为 `message` 的共享数据。然后,在 `ChildA` 和 `ChildB` 组件中,可以使用 `inject` 方法注入该数据:
```html
<!-- ChildA.vue -->
<template>
<div>
<p>{{ message }}</p>
<button @click="changeMessage">Change message</button>
</div>
</template>
<script>
import { inject } from 'vue'
export default {
setup() {
const message = inject('message') // 注入共享数据
function changeMessage() {
message.value = 'Hello, Vue3!'
}
return {
message,
changeMessage
}
}
}
</script>
```
```html
<!-- ChildB.vue -->
<template>
<div>
<p>{{ message }}</p>
</div>
</template>
<script>
import { inject } from 'vue'
export default {
setup() {
const message = inject('message') // 注入共享数据
return {
message
}
}
}
</script>
```
在上面的代码中,`ChildA` 组件中通过 `inject` 方法注入了 `message` 数据,并且提供了一个修改数据的方法 `changeMessage`。`ChildB` 组件中也通过 `inject` 方法注入了 `message` 数据,然后直接使用了该数据。
这样,当 `ChildA` 组件中的按钮被点击时,就可以修改 `message` 数据,然后 `ChildB` 组件中的数据也会随之更新。这就实现了兄弟组件之间的通信。
阅读全文