有没有熟悉 ts 的大佬,想问类型定义的问题

2022-06-22 14:48:39 +08:00
 mokevip

需求描述

大概意思是请求时大部分接口需要用到

{
	page: 1,
	limit: 50
}

但是实际请求时参数可能是

{
	page: 1,
	limit: 50,
	id: 40,
	name: '王'
}

正常会需要

interface AReq extends PageDto {
	id: 40,
	name: '王'
}

function getName(data: AReq){}

想要实现的效果

function getName(data: PageDto<{
	id: 40,
	name: '王'
}>){}

个人认为这样可以少定义一些内容,让单个请求整体性更强。 但是不知道怎么写

尝试

大概了解泛型,但是目前尝试下来只能映射子级的,如

export interface PageDto<T> {
	page: 1,
	limit: 50,
    data: T
}

还有用泛型合并,但是,代码提示:'应为“?”' 不太清楚写法具体是怎么样的

export type Concat<T, U> = T extends U;

问题

请问有什么方法能够复用定义在同一级扩展呢?

804 次点击
所在节点    问与答
7 条回复
TWorldIsNButThis
2022-06-22 14:56:31 +08:00
page 和 query 应该分成两个参数吧
TWorldIsNButThis
2022-06-22 14:57:56 +08:00
一定要这么做的话,直接 T&U 不就好了
AlekoShen
2022-06-22 14:58:18 +08:00
不会 ts 但看女票玩过这个 https://github.com/type-challenges/type-challenges/blob/main/README.zh-CN.md
我记得有类似的语法 依稀记得是在简单题里面有类似的 如果是想学 TS 类型系统 我觉得这个网站是一个很不错的选择
hua123s
2022-06-22 15:06:26 +08:00
export type PageDto<T> = {
page: 1;
limit: 50;
} & T;
hronro
2022-06-22 15:06:26 +08:00
export type PageDto<T extends object>={
[key in keyof T]: T[key];
}&{
page: number;
limit: number;
};
noe132
2022-06-22 15:16:33 +08:00
type WithPageAndLimit<T> = T & { page: number, limit: number }
mokevip
2022-06-22 15:20:48 +08:00
@TWorldIsNButThis
@hua123s
@hronro
@noe132

感谢回复在各位告知之前从来没看到类似的文档。。。刚刚已经试了,可以了,谢谢大家

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/861378

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX