javascript - 泛型 : Type as property name

标签 javascript typescript

是否可以使用泛型将对象不仅作为类型,而且作为键来传递?

interface store {
  category: string
}

interface ajaxResponse<T> {
  data: ajaxData<T>
  errors: string[]
  success: boolean
}

interface ajaxData<T> {
  rewards: {
    amount: number
    error: string
  }
  T: T
}

function get<T>(url): Promise<ajaxResponse<T>> {
    // make ajax GET request
    // return json object
}

let res = await get<store>('/my/url')

res.data.store.category

当我这样做时,它说

Property 'store' does not exist on type 'ajaxData'

我有办法访问该属性吗?它一旦编译就可以工作,因为所有的东西都被删除了,但是我怎样才能让它在编辑器中工作?

编辑

想了想,我觉得不希望接口(interface)和属性是一样的。我想我想使用名称为 xinterface,所以可能是这样的:

let res1 = await get<storeA, 'category'>('/my/url1')
let res2 = await get<storeB, 'catList'>('/my/url2')

res1.data.category.category
res2.data.catList.categories

最佳答案

是的,如果您将属性名称作为显式文字类型,您可以使用 mapped type syntax 声明具有该名称属性的类型:

type A<T, PropertyName extends string> = {[P in PropertyName]: T}

所以完整的例子应该是这样的

interface store {
  category: string
}

interface ajaxResponse<T, PropertyName extends string> {
  data: ajaxData<T, PropertyName>
  errors: string[]
  success: boolean
}

type ajaxData<T, PropertyName extends string> = {
  rewards: {
    amount: number
    error: string
  }
} & {[P in PropertyName]: T}




function get<T, PropertyName extends string>(url): Promise<ajaxResponse<T, PropertyName>> {
    // make ajax GET request
    // return json object
  return null;
}

async function test() {
  let res = await get<store, 'store'>('/my/url')

  res.data.store.category
}

关于javascript - 泛型 : Type as property name,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47044401/

相关文章:

javascript - 在 Javascript 中,如果有一个对象有很多函数属性,你如何将它们转换为字符串数组(函数名称)?

typescript - 你能在 TypeScript 中扩展 HTMLDivElement 吗?

typescript - 我如何禁用/处理初始化,toJSON

typescript - 将 Typescript 更新为 v3.2.1,SDK 文件夹中没有 tsc.exe

javascript - Angular Material MatChipList - 如何在动态 FormArray 上使用它?

javascript - 带双引号的标签在浏览器中会产生错误 "Invalid Label"

javascript - 我可以使用 javascript 在每隔一行插入一些字符串吗?

javascript - 未捕获的 TypeError : Failed to construct 'File' : Please use the 'new' operator, 此 DOM 对象构造函数不能作为函数调用

javascript - Three.js 初学者卡在第一步 : "undefined is not a function"

javascript - 来自 Mongoose 的类型错误