首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >TypeScript对象类型断言不工作

TypeScript对象类型断言不工作
EN

Stack Overflow用户
提问于 2021-10-20 09:57:26
回答 1查看 49关注 0票数 0
代码语言:javascript
复制
type ConfigItem<T> = {
  label: string;
  name: keyof T;
};

type P1 = {
  E1: {
    A: "xl",
    B: "xl",
    C: "xl",
    D: "xl",
  },
  E2: {
    AA: "xxl",
    BB: "xxl",
    CC: "xxl",
    DD: "xxl",
  },
};

export const Configs = {
  X1: [
    { label: "ax", name: "A2" }, // ⬅️ Why is it not restricted?
    { label: "bx", name: "B" },
    { label: "cx", name: "C" },
    { label: "dx", name: "D2" }, // If the last one is not in E1, an error is reported.
  ] as ConfigItem<P1["E1"]>[],
  X2: [
    // ...
  ]
};

只有当数组中的最后一项具有错误的值类型时,才会报告错误。

当最后一项正确时,前一项不正确,则不会报告错误。

代码语言:javascript
复制
"typescript": "^4.4.4"

更新:是唯一的方法吗?

代码语言:javascript
复制
const X1: ConfigItem<P1["E1"]> = [
  { label: "ax", name: "A2" },
  { label: "bx", name: "B" },
  { label: "cx", name: "C" },
  { label: "dx", name: "D" },
];

export const Configs = {
  X1,
  X2: []
};
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-10-20 10:03:06

当您使用as [[typename]]符号时,不会执行类型检查,因为您正在手动告诉编译器,您确信这是正确的。

要启用类型检查,您要做的是:

代码语言:javascript
复制
type ConfigItem<T> = {
  label: string;
  name: keyof T;
};

type P1 = {
  E1: {
    A: "xl",
    B: "xl",
    C: "xl",
    D: "xl",
  },
  E2: {
    AA: "xxl",
    BB: "xxl",
    CC: "xxl",
    DD: "xxl",
  },
};

export const Configs: {X1: ConfigItem<P1["E1"]>[], X2: any /*define next here*/} = {
  X1: [
    { label: "ax", name: "A2" },
    { label: "bx", name: "B" },
    { label: "cx", name: "C" },
    { label: "dx", name: "D2" },
  ],
  X2: [
    // ...
  ]
};
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69643910

复制
相关文章

相似问题

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