如何在接口中引用动态TypeScript属性?

9njqaruj  于 2023-03-24  发布在  TypeScript
关注(0)|答案(1)|浏览(102)

我试图键入一个主题对象,将与Tailwind一起使用,我试图实现的是在主题签名中动态提供类型:

export interface Theme {
  screens: {
    [key: string]: string;
  };
  bps: keyof this['screens'][]; // breakpoints
};

我试图实现的是提供一个接口来配置主题,但编译器一直在抱怨。理想情况下,接口的实现如下所示:

// good example
const t: Theme = {
    screens: {
        sm: "200px",
        md: "400px"
    },
    bps:["md"] // md exists in screens
}

// bad example
const tt: Theme = {
    screens: {
        sm: "200px",
        md: "400px"
    },
    bps:["foo"] // foo is not a key of screens
}
gcuhipw9

gcuhipw91#

据我所知,唯一的方法是使Theme通用,这样我们就可以推断出键的类型,并且为了避免显式指定该类型,我们必须在创建主题时使用一个不做任何事情的函数。
它看起来像这样:

export interface Theme<Screens extends Record<string, string>> {
    screens: Screens;
    bps: (keyof Screens)[]; // breakpoints
}

function buildTheme<Screens extends Record<string, string>>(
    theme: Theme<Screens>
) {
    return theme;
}

// good example
const t = buildTheme({
    screens: {
        sm: "200px",
        md: "400px",
    },
    bps: ["md"], // Okay
});

// bad example
const tt = buildTheme({
    screens: {
        sm: "200px",
        md: "400px",
    },
    bps: ["foo"], // Error as desired:
    //    ^^^^^−−−−−Type '"foo"' is not assignable to type '"sm" | "md"'.ts(2322)
});

Playground链接

相关问题