让前端飞Web前端之路

以对象所有的key作为type

2023-03-08  本文已影响0人  小光啊小光

1.未定义类型对象

const obj = {
    a: 1,
    b: 1,
    c: 1,
}

type ObjKey = keyof typeof obj // type ObjKey = "a" | "b" | "c"

2.定义类型的对象

当希望约定obj的类型时,便无法推导出key

const obj: Record<string, number> = {
    a: 1,
    b: 1,
    c: 1,
}

type ObjKey = keyof typeof obj // type ObjKey = string

方法1: 符合TS规范的书写方式(非推导,只是提前声明)

type ObjKey = "a" | "b" | "c"
const obj: Record<ObjKey, number> = {
    a: 1,
    b: 1,
    c: 1,
}

方法2:使用声明函数(可推导,但要写一个与业务不相关的func)

function defineObj<T extends string>(obj: Record<T, number>) {
    return obj
}
const obj = defineObj({
    a: 1,
    b: 1,
    c: 1,
})
type ObjKey = keyof typeof obj // type ObjKey = "a" | "b" | "c"
上一篇 下一篇

猜你喜欢

热点阅读