我有以下代码:
let show = {
createTag: false,
updateFeature: false,
createFeatureGroup: false,
deleteFeature: false,
deleteCycle: false,
};
我从查询字符串中得到一个值,我想与 show 的键匹配。
以下代码可以正常工作,但我想要一种方法让 Typescrpt 推断它并避免发出强制转换:
const showDialog = $page.query.get('show') || '';
if (showDialog && showDialog in show) {
// I want to get rid of the "<keyof typeof show>" cast
show[<keyof typeof show>showDialog] = true;
}
我虽然只是发出 showDialog in show
typescript会知道 if
showDialog 里面是 show
的键,但似乎并非如此。
@paolostyle 提供的类型保护非常特定于
show
对象。以下代码段更通用,可用于任何对象中的任何键: