首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >重写嵌套类型记录接口中的属性

重写嵌套类型记录接口中的属性
EN

Stack Overflow用户
提问于 2019-09-08 10:03:46
回答 1查看 2K关注 0票数 0

我有一个类似于这样的类型记录界面:

代码语言:javascript
运行
复制
interface DataSku {
  fields: {
    sku: string;
  }
}

interface PostProduct {
  fields: {
    title: string;
    skus: DataSku[];
  }
}

现在,我想扩展Product接口,以便skus数组中的每个对象都有一个额外的字段。所以我试了一下:

代码语言:javascript
运行
复制
interface Sku extends DataSku {
  stripe: Stripe.skus.ISku;
}

interface Product extends PostProduct {
  fields: PostProduct['fields'] & {
    skus: Sku[];
  }
}

在我的代码中,我尝试这样的循环:

代码语言:javascript
运行
复制
(product as Product).fields.skus.forEach(sku => console.log(sku.stripe));

这会引发以下类型记录错误:

代码语言:javascript
运行
复制
Property 'stripe' does not exist on type 'DataSku'.

我把接口扩展错了吗?控制台按照预期输出我的条带对象,所以只是类型记录不满意定义。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-09-08 10:11:18

对于这一点,一种更优雅(也更有效)的方法是使用仿制药

使用用于fields.skus类型的泛型参数更新fields.skus

代码语言:javascript
运行
复制
interface PostProduct<T extends DataSku = DataSku> {
  fields: {
    title: string;
    skus: T[];
  }
}

T extends DataSku意味着该类型必须是DataSku的一个子类型。我们甚至可以为T设置一个默认值,这样也可以使用PostProduct而不必指定泛型参数。

现在,对于Product,我们只需将Sku作为泛型参数传递:

代码语言:javascript
运行
复制
interface Product extends PostProduct<Sku> {}

游乐场

也就是说,如果您想不使用泛型,也不需要修改DataSkuPostProduct。你可以这样做:

代码语言:javascript
运行
复制
interface Product extends PostProduct {
  fields: Omit<PostProduct['fields'], 'skus'> & {
    skus: Sku[];
  }
}

游乐场

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57840944

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档