typescript怎么让泛型同级呢?

需求描述

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

{
    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;

问题

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

讨论数量: 1
interface Page {
  page: number
  limit: number
}

interface User {
  id: number
  name: string
}

type UserData = User & Page

const user: UserData = {
  page: 1,
  limit: 10,
  id: 1,
  name: 'hehe',
}
1年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!