vue3的defineEmits的三种定义和它的四种用法
ztj100 2025-01-05 01:02 12 浏览 0 评论
vue3里的defineEmits是用来定义事件,避免父子组件形成互相的数据耦合依赖,在大型工程里面降低数据状态的混乱结局。
它有三种定义,我们一般都是直接用最简单的defineEmits(["event1"])写法就完事了,不过它还有两种骚定义方法和使用方法。
第一种方法
export declare function defineEmits<EE extends string = string>
(emitOptions: EE[]): EmitFn<EE[]>;
这种情况是最简单的,在使用的时候我们只需要在defineEmits的入参里面定义一个字符串的数组即可:
const emits2 = defineEmits(["event1"]);
...
emits2("event1", 'eventValue');
第二种方法
export declare function defineEmits<E extends EmitsOptions = EmitsOptions>
(emitOptions: E): EmitFn<E>;
...
export type EmitsOptions = ObjectEmitsOptions | string[];
...
export type ObjectEmitsOptions =
Record<string, ((...args: any[]) => any) | null>;
从上面这个方法申明来看,我们可以看到defineEmits可以接收一个Record<string, ((...args: any[]) => any) | null>类型作为入参。
const emits = defineEmits({
event1: (val: string) => {
return val;
},
});
...
emits("event1", 'eventValue');
在这种应用方法中,我们实际上是定义了一个函数实例,ts反向根据这个函数进行类型推断,来获取参数和返回值类型。
第三种方法
export declare function defineEmits<T extends
((...args: any[]) => any) | Record<string, any[]>>():
T extends (...args: any[]) => any ? T : ShortEmits<T>;
- 第一种情况
T extends (...args: any[]) => any
在这里泛型T是一个函数,这个函数的入参和出参都是任意类型,那么我们基本可以不看代码就能知道它需要传入俩参数,第一个是定义事件名字,第二个则是事件值:
const emits = defineEmits<(param: "event32", val: string) => string>();
...
emits('event32', 'event32Value')
- 第二种情况
T extends Record<string, any[]>>()
这个情况下泛型T是一个Record<string, any[]>>()类型,key是时间名字,而后面的值就是事件值,使用方法如下:
const emits = defineEmits<{ event31: string[] }>();
...
emits('event', 'eventValue')
备注:看到没,T extends Record<string, any[]>>(),这里面的值是一个数组哦,也就是说我们在实际emit的时候可以返回多个值哦。比如下面的语句:
emits('event31', '事件31', '事件311')
// 接收端
@event31="(v, v2) => console.log(v, v2)"
相关推荐
- Linux日志相关命令—查看\关键词查询\截取\日志压缩备份
-
一、查看1、动态日志查看。说明:程序启动可以动态查看运行日志。...
- Dify+微信智能生态:手把手教你搭建私有化客服解决方案
-
一、Dify简介1.为什么要使用Dify?零代码门槛:通过直观界面和预设模板,非技术人员也能快速创建智能助手1。模型生态丰富...
- 小白入门必知必会-RocketMQ安装(rocketmq下载安装)
-
一RocketMQ基础1.1介绍MQ是一种提供消息队列服务的中间件,也称为消息中间件,是一套提供了消息生产、存储、消费全过程API的软件系统。RocketMQ是使用Java语言开发的一款MQ产品,...
- Linux搭建Weblogic集群(linux weblogic安装与配置图文详解)
-
一、Java环境配置拿到新申请的两台Linux机器后,首先需要安装JDK,下载地址请戳这里。1、执行命令:rpm-qa|grepjava,查询是否存在系统自带的openjdk。如果为空,...
- 从0开始,让你的Spring Boot项目跑在Linux服务器
-
1搭建Linux服务器1.1购买阿里云服务器或安装虚拟机这里建议是CentOS7.X或CentOS8.X,当然其他的Linux如deepin、Ubuntu也可以,只是软件环境的安装包和安装方式...
- 搞定这8个Kafka生产级容量评估,每日10亿+请求轻松拿捏
-
本篇文章通过场景驱动的方式来深度剖析Kafka生产级容量评估方案如何分析,申请和实施。...
- 还在用nohup启动java jar服务?试试强大的systemctl吧
-
nohup直译过来就是不挂断,要运行后台中的nohup命令,添加&(表示“and”的符号)到命令的尾部,使用nohup启动的例子:nohup/usr/bin/java-jar/dat...
- prometheus、exporter和grafana的简单使用
-
一、基本介绍1、prometheusPrometheus(普罗米修斯)是一套开源的监控&报警&时间序列数据库的组合,由SoundCloud公司开发。...
- Mock工具之Moco使用教程(mock 工具)
-
目录一、什么是Moco二、安装&配置...
- SpringBoot入门系列(三十)Spring Boot项目打包、发布与部署
-
今天介绍SpringBoot项目是如何打包、发布的。SpringBoot使用了内嵌容器,因此它的部署方式也变得非常简单灵活,一方面可以将SpringBoot项目打包成独立的jar或者war包来运...
- chatgpt-on-wechat:智能对话的全新可能与开源魅力
-
简介chatgpt-on-wechat(简称CoW)项目是基于大模型的智能对话机器人,支持微信公众号、企业微信应用、飞书、钉钉接入,可选择GPT3.5/GPT4.0/Claude/Gemini/Lin...
- 免费快速实现内网穿透:windows远程桌面连接实战
-
本次介绍使用frp实现内网穿透,文章是之前写的,写了很多篇,后续会一一整理出来,希望帮助到有需要的朋友。frp简介...
- 手摸手教你 CentOS 入门必备基础知识(建议收藏)
-
这里记录一下我的CentOS学习过程,相当于自己记个笔记,同时分享出来,如果有同学刚好有需要而这个文章帮助到了你的话,在下也会十分开心。文章最后推介了几个免费视频,B站和慕课上的免费学习视频挺多...
- 分布式数据库基础性能测试(分布式数据库实验)
-
最近对原生HTAP(cockroachdb和tidb)数据库同时以数仓为起点做HTAP数据库的greenplum进行了相关场景性能测试,场景分为OLTP的TPC-C和TPC-B测试以及简单的OL...
-
- 使用X11VNC远程连接统信UOS(vnc 远程连接)
-
原文链接:使用X11VNC远程连接统信UOS...
-
2025-05-02 14:51 ztj100
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- Linux日志相关命令—查看\关键词查询\截取\日志压缩备份
- Dify+微信智能生态:手把手教你搭建私有化客服解决方案
- 小白入门必知必会-RocketMQ安装(rocketmq下载安装)
- Linux搭建Weblogic集群(linux weblogic安装与配置图文详解)
- 从0开始,让你的Spring Boot项目跑在Linux服务器
- 搞定这8个Kafka生产级容量评估,每日10亿+请求轻松拿捏
- 还在用nohup启动java jar服务?试试强大的systemctl吧
- prometheus、exporter和grafana的简单使用
- Mock工具之Moco使用教程(mock 工具)
- SpringBoot入门系列(三十)Spring Boot项目打包、发布与部署
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- node卸载 (33)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- exceptionininitializererror (33)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)