微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在打字稿接口中编写类型对象的接口

如何解决在打字稿接口中编写类型对象的接口

这是我的数据结构,我该如何为其编写接口?

const TransitReport: {
        title: string;
        client: string;
        data: {
            overdueReviews: number;
            outstandingCovenantBreaches: number;
            outstandingMarginingBreaches: number;
            periodStartDate: string;
            periodEndDate: string;
        };
    }[]

我试过了:

export interface TransitReport {
  title: string;
  client?: string;
  data: Record<string,unkNown>;
  overdueReviews: number;
  outstandingCovenantBreaches: number;
  outstandingMarginingBreaches: number;
  periodStartDate: string;
  periodEndDate: string;
}

这有点适用于模拟 API 调用数据,但在编写测试用例时,我遇到了以下错误

输入'

{ title: string; 
client: string; 
data: { 
overdueReviews: number; 
outstandingCovenantBreaches: number; 
outstandingMarginingBreaches: number; 
periodStartDate: string;
periodEndDate: string; 
}; }' 

缺少类型中的以下属性 'TransitReport':overdueReviews、outstandingCovenantBreaches、outstandingMarginingBreaches、 periodStartDate、 periodEndDate

解决方法

打破你的界面TransitReport如下代码片段,因为你需要在数据记录下提供overdueReviews,periodEndDate等。否则,它会检查您的根 TransitReport 对象下不存在的那些属性。

export interface TransitReport {
    title: string;
    client?: string;
    data: DataRecord;
}

export interface DataRecord {
    overdueReviews: number;
    outstandingCovenantBreaches: number;
    outstandingMarginingBreaches: number;
    periodStartDate: string;
    periodEndDate: string;
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。