【Vue3进阶】组件通信进阶使用方法——defineProps、defineExpose、defineEmits

组件通信

父传子

defineProps

在 Vue 3 中,defineProps 是一个用于在 <script setup> 语法中定义组件的 props 的函数。这个函数提供了一种更加明确和类型安全的方式来定义子组件的 props,使得子父组件之间的数据传递更加清晰和可维护。以下是 defineProps 的基本使用方式:

基本用法:

  1. 导入 defineProps 函数
    首先,你需要从 vue 包中导入 defineProps 函数。

    import { defineProps } from 'vue';
    
  2. 使用 defineProps 定义 Props
    <script setup> 中,使用 defineProps 来定义你的组件 props。你可以传递一个对象,对象的属性就是你想要定义的 props,以及它们的类型和验证器。

    <script setup>
    import { defineProps } from 'vue';
    const props = defineProps({title: String,message: {type: String,default: ''},count: {type: Number,required: true}
    });
    </script>
    

    在这个例子中,title 是一个字符串类型的 prop,message 是一个带有默认值的字符串类型的 prop,而 count 是一个必需的数字类型的 prop。

  3. 在模板中使用 Props
    定义了 props 之后,你可以在组件的模板中像使用数据一样使用它们。

    <template><div><h1>{{ title }}</h1><p>{{ message }}</p><button @click="count++">Count is: {{ count }}</button></div>
    </template>
    

子传父

ref+defineExpose

采用setup模式

在 Vue 3 中,setup 函数是 Composition API 的入口点。它在组件创建之前执行,并且接收两个参数:propscontextsetup 函数可以返回一个对象,其中的属性和方法将会被暴露给模板或其他 Composition API 函数。

子组件:image-20241209103708547

父组件:image-20241209103753949

方法:

  1. 通过在父组件中去定义ref变量
    image-20241209104333623
  2. 然后子组件做一个主动暴露
    image-20241209104240683
  3. 父组件通过.value.方法()的方式拿到子组件提供的方法
    image-20241209104208105
  4. 然后在父组件中就会执行子组件的方法
    image-20241209104151239
采用export default模式

在 Vue 2 中,我们通常使用 export default 来定义组件。在 Vue 3 中,虽然 setup 函数是推荐的写法,但仍然可以通过 export default 来定义组件,并且使用 Composition API。

子组件:image-20241209104628905

父组件:image-20241209104646815

总结

  • setup 模式:推荐使用,更符合 Vue 3 的设计理念。通过 defineExpose 明确地控制哪些属性和方法被暴露给父组件或子组件。
  • export default 模式:兼容 Vue 2 的写法,可以使用 this.$expose 来暴露方法,但不是最佳实践。

在实际开发中,推荐使用 setup 模式,因为它提供了更好的类型推断和更清晰的代码结构。

defineEmits

如果你想要实现子组件向父组件传递数据或事件,你应该使用 defineEmits。以下是 defineEmits 的基本用法:

  1. 导入 defineEmits 函数

    import { defineEmits } from 'vue';
    
  2. 使用 defineEmits 定义 emits
    <script setup> 中,使用 defineEmits 来定义你的组件可以触发的事件。

    <script setup>
    import { defineEmits } from 'vue';
    const emit = defineEmits(['update', 'click']);
    </script>
    
  3. 触发事件
    在子组件中,你可以使用 emit 函数来触发定义的事件,并向父组件传递数据。

    <script setup>
    import { defineEmits } from 'vue';
    const emit = defineEmits(['update', 'click']);function someMethod() {emit('update', newValue);
    }
    </script>
    
  4. 在父组件中监听事件
    父组件可以通过 v-on@ 语法来监听子组件触发的事件。

    <template><ChildComponent @update="handleUpdate" @click="handleClick" />
    </template>
    

这样,当子组件触发 updateclick 事件时,父组件的相应方法会被调用,并且可以接收子组件传递的数据。这是 Vue 中实现父子组件通信的一种方式。

defineExpose和defineEmits的区别

  1. defineExpose
    • defineExpose用于在<script setup>语法糖的组件中明确要暴露出去的属性和方法,使得父组件可以通过ref访问子组件的这些属性和方法。
    • 它通常用在子组件中,将子组件中的属性或方法暴露给父组件。父组件可以通过ref获取子组件实例,并直接访问这些暴露的属性和方法。
    • defineExpose必须在变量和方法声明定义之后使用,否则可能会引起警告甚至页面卡死。
  2. defineEmits
    • defineEmits用于子组件向父组件传递事件,即子组件可以通过defineEmits声明可以触发的事件,然后在需要的时候触发这些事件,父组件通过监听这些事件来接收数据。
    • 它允许子组件显式地声明要触发的事件,并在子组件中通过emits函数触发这些事件,父组件通过监听这些事件来响应。
    • defineEmitsdefineProps一样,只能在<script setup>中使用,并且不需要导入即可使用。

总结来说,defineExpose主要用于子组件向父组件暴露属性和方法,而defineEmits主要用于子组件向父组件传递事件。两者都是Vue 3中组件间通信的重要工具,但它们的使用场景和目的有所不同。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/488687.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

day11 性能测试(4)——Jmeter使用(黑马的完结,课程不全)直连数据库+逻辑控制器+定时器

【没有所谓的运气&#x1f36c;&#xff0c;只有绝对的努力✊】 目录 1、复习 1.1 断言&#xff08;3种&#xff09; 1.2 关联&#xff08;3种&#xff09; 1.3 录制脚本 2、Jmeter直连数据库 2.1 直连数据库——使用场景 2.2 直连数据库——操作步骤 2.2.1 案例1&…

如何将CSDN的文章保存为PDF?

目录 1、打开CSDN文章2、按F12或者鼠标右键选择检查并进入控制台3、在控制台输入以下代码4、然后回车&#xff08;Enter&#xff09;如果纵向显示不全就横向 1、打开CSDN文章 2、按F12或者鼠标右键选择检查并进入控制台 3、在控制台输入以下代码 (function(){ $("#side&q…

ubuntu22.04 使用crash

文章目录 前言一、apt 安装dbgsym vnlinux二、使用.ddeb包安装dbgsym vnlinux三、dbgsym发行版四、crash调试参考资料 前言 最近在适配 ubuntu系统&#xff0c;记录一下其crash的安装。 一、apt 安装dbgsym vnlinux # echo "deb http://ddebs.ubuntu.com $(lsb_release…

刷题日志【4】

目录 1、猜数字大小 1、猜数字大小 题意有点抽象&#xff0c;我大概讲一下&#xff0c;就是在1——n里面会有一个目标数&#xff0c;我们通过猜数字的方式逼近这个数字&#xff0c;直到解出这个数&#xff0c;之前我们是用二分法求最快达到求解的问题&#xff0c;这道题多了每…

【蓝桥杯最新板】蓝桥杯嵌入式液晶上实现电子时钟

这几年蓝桥杯比赛比较适合学生技能学习&#xff0c;考虑板子功能&#xff0c;提出完成的任务。 要求在液晶完成如下图效果&#xff1a; 主要是实现液晶显示时钟和数字时钟&#xff0c;具体样式可以依据实际情况微调。 实现过程&#xff1a; 1.需要画圆&#xff08;外圆、内圆…

Python知识分享第25天-快速排序算法

快速排序算法 快速排序&#xff08;QuickSort&#xff09;是一种基于分治法的高效排序算法。它通过选择一个“基准”元素&#xff0c;将数组分成两个子数组&#xff0c;其中一个子数组的所有元素都比基准小&#xff0c;另一个子数组的所有元素都比基准大&#xff0c;然后递归地…

Hive3.X——异常处理Could not create ServerSocket on address 0.0.0.0/0.0.0.0:10000

Hive3.X——异常处理Could not create ServerSocket on address 0.0.0.0/0.0.0.0:10000 01 前言 大数据系列&#xff0c;学到了Hive&#xff0c;搭建环境的时候&#xff0c;因为使用的是本机WSL2&#xff08;别问为啥不用VMware&#xff0c;问就是条件有限&#xff0c;而且WS…

[Java] 使用 VSCode 来开发 Java

目录 前言Java 环境怎么看自己是否已经配置完成&#xff1f;安装 JDK安装 Maven 环境修改 Maven 依赖源 完善 VS Code配置插件配置 Maven配置 Maven Settings配置 Maven 可执行文件地址 前言 由于使用 VSCode 编码已经成为习惯&#xff0c;并且它确实相对其他的 IDE 较为轻量化…

悬赏任务源码(悬赏发布web+APP+小程序)开发附源码

悬赏任务源码是指一个软件或网站的源代码&#xff0c;用于实现悬赏任务的功能。悬赏任务是指发布方提供一定的奖励&#xff0c;希望能够找到解决特定问题或完成特定任务的人。悬赏任务源码通常包括任务发布、任务接受、任务完成和奖励发放等功能的实现。搭建悬赏任务源码是一个…

可视化建模以及UML期末复习----做题篇

一、单项选择题。&#xff08;20小题&#xff0c;每小题2分,共40分&#xff09; 1、UML图不包括&#xff08; &#xff09; A、用例图 B、状态机图 C、流程图 D、类图 E、通信图 答案&#xff1a;C、流程图 UML中不包括传统意义上的流程图&#xff0c;流程图通常是指B…

SpringBoot中使用MyBatis-Plus详细介绍

目录 一、MyBatis-Plus的使用步骤 1.引入MybatisPlus的起步依赖 2.定义Mapper&#xff08;也叫dao&#xff09;层的接口 3.MyBatis-Plus中常用注解 4. 使用MyBatis-Plus时要做如下配置 5.条件构造器 Wrapper 一、MyBatis-Plus的使用步骤 1.引入MybatisPlus的起步依赖 My…

操作系统(4)操作系统的结构

一、无序结构&#xff08;整体结构或模块组合结构&#xff09; 1.特点&#xff1a; 以大型表格和队列为中心&#xff0c;操作系统的各部分程序围绕着这些表格进行。操作系统由许多标准的、可兼容的基本单位&#xff08;称为模块&#xff09;构成&#xff0c;模块之间通过规定的…

Windows桌面系统管理0:总目录

目 录 Windows桌面系统管理1计算机硬件组成及组装-CSDN博客文章浏览阅读353次&#xff0c;点赞14次&#xff0c;收藏3次。计算机硬件组成及组装https://blog.csdn.net/2401_86296728/article/details/144431553?fromshareblogdetail&sharetypeblogdetail&sharerId14…

在CentOS中安装和卸载mysql

在CentOS7中安装和卸载mysql 卸载mysql1、查看是否安装过mysql2、查看mysql服务状态3、关闭mysql服务4、卸载mysql相关的rpm程序5、删除mysql相关的文件6、删除mysql的配置文件my.cnf 安装mysql1、下载mysql相关的rpm程序2、检查/tmp临时目录权限3、安装mysql前的依赖检查3、安…

印闪网络:阿里云数据库MongoDB版助力金融科技出海企业降本增效

客户背景 上海印闪网络科技有限公司&#xff0c;于2017年1月成立&#xff0c;投资方包括红杉资本等多家国际知名风投公司。公司业务聚焦东南亚普惠金融&#xff0c;常年稳居行业头部。创始团队来自腾讯&#xff0c;中国团队主要由运营、风控及产研人员组成&#xff0c;核心成员…

网络基础 - TCP/IP 五层模型

文章目录 一、OSI 参考模型中各个分层的作用1、应用层2、表示层3、会话层4、传输层5、网络层6、数据链路层7、物理层 一、OSI 参考模型中各个分层的作用 1、应用层 2、表示层 负责设备固有数据格式和网络标准数据格式间的转换 3、会话层 4、传输层 负责连接的建立和断开&…

【数据结构——内排序】希尔排序(头歌实践教学平台习题)【合集】

目录&#x1f60b; 任务描述 测试说明 我的通关代码: 测试结果&#xff1a; 任务描述 本关任务&#xff1a;实现希尔排序算法。 测试说明 平台会对你编写的代码进行测试&#xff1a; 测试输入示例&#xff1a; 10 9 8 7 6 5 4 3 2 1 0 (说明&#xff1a;第一行是元素个数&a…

网络编程 | TCP套接字通信及编程实现经验教程

1、TCP基础铺垫 TCP/IP协议簇中包含了如TCP、UDP、IP、ICMP、ARP、HTTP等通信协议。TCP协议是TCP/IP协议簇中最为常见且重要的通信方式之一&#xff0c;它为互联网上的数据传输提供了可靠性和连接管理。 TCP&#xff08;Transmission Control Protocol&#xff0c;传输控制协议…

【最新】北大数字普惠金融指数数据集-省市县(2011-2023年)

一、数据介绍 数据名称&#xff1a;第六期北大数字普惠金融指数-省市县 数据年份&#xff1a;2011-2023年 数据范围&#xff1a;全国31个省、337个地级以上城市以及2800个县 数据说明&#xff1a;编制方法请参阅《经济学&#xff08;季刊&#xff09;》中的《测度中国数字普…

GNSS误差源及差分定位

GNSS误差源&#xff1a; &#xff08;一&#xff09;卫星星历误差 由星历信息所得出的卫星位置坐标与实际位置坐标的偏差就是星历误差。星历信息是由 GPS 地面部分测量计算后传入空间部分的。由于卫星在运动中要受到各种摄动力的作用, 而地面部分又很难精确测量这些作用力,…