Vue3组件通信方式

1. 常用的组件通信方式:

props:可以实现父子组件、子父组件、甚至兄弟组件通信

自定义事件:可以实现子父组件通信

全局事件总线$bus:可以实现任意组件通信

pubsub:发布订阅模式可以实现任意组件通信

vuex:集中式状态管理容器,实现任意组件通信

ref:父组件获取子组件实例VC,获取子组件的响应式数据以及方法

slot:插槽(默认插槽、具名插槽、作用域插槽)实现父子组件通信

2. props

可以实现父子组件通信,props数据是只读的。

子组件使用defineProps方法去接受父组件传递过来的数据;

举个例子:

父组件:

<template>
    <div>我是父组件</div>
    <Child info='曹操' :money="money" />
</template>

<script setup lang="ts">
import Child from './child.vue'
import ref from 'vue'
money = ref('100')
</script>

<style scoped>
</style>

子组件:

<template>
    <div class="son">
        <h1>我是子组件</h1>
        <p>{{props.info}}</p>
        <p>{{props.money}}</p>
        <!--props可以省略前面的名字-->
        <p>{{info}}</p>
        <p>{{money}}</p>
    </div>
</template>

<script setup lang="ts">
let props = defineProps(['info', 'money'])
</script>

<style scoped>
<style>

3. 自定义事件

在vue框架中事件分为两种:一种是原生的DOM事件,另外一种是自定义事件;

所谓的原生dom事件即可以让用户与网页进行交互,比如click、dbclick、change、mouseleave......

自定义事件即可以实现子组件给父组件传递数据。

利用defineEmits方法返回函数触发自定义事件。defineEmits方法不需要引入直接使用。

持续更新中...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值