乐趣区

关于javascript:ts7053的另一种解法

刚接触 ts,以前习惯用对象写个配置,而后依据参数判断配置是否存在,不存在间接返回一个默认配置:

ts 马上会抗议说:你的对象里只有固定的几个 key,不能用不确定的 string 或者 number 作为 key 啊!

有时候真感觉 ts 是不是傻?

从网上能找到的个别解决方案是,把配置的类型确定一下,变成这样:

const statusConfig: {[k: number]: string} = {
  0: '设施在线',
  1: '设施离线',
  2: '查问状态中',
}

function getDescOfStatus(status: number) {return statusConfig[status] || '未知状态'
}

然而有时候这种配置会放在对立的一个中央,或者放进一个大对象,每次都写这个也太麻烦了,而且这种配置个别就两三个中央会用到,于是发现了上面这种写法:

const statusConfig = {
  0: '设施在线',
  1: '设施离线',
  2: '查问状态中',
}

function getDescOfStatus(status: keyof typeof statusConfig) {return statusConfig[status] || '未知状态'
}

还能带个枚举类型的查看:


其实 getDescOfStatus 函数反对所有 number 和 string,以上的办法仿佛限度得太死了,所以咱们还能够这样改改函数:


const statusConfig = {
  0: '设施在线',
  1: '设施离线',
  2: '查问状态中',
}

function getDescOfStatus(status: string | number) {return statusConfig[status as keyof typeof statusConfig] || '未知状态'
}
退出移动版