百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

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(vnc 远程连接)

原文链接:使用X11VNC远程连接统信UOS...

2025-05-02 14:51 ztj100

取消回复欢迎 发表评论: