如何使用 unknown 检查对象类型?

2019-08-22 18:36:58 +08:00
 iugo
```
function check(v: unknown): v is { name: string; age: number } {
if (typeof v !== 'object' || v === null) {
return false;
}
const a = v as { name: unknown; age: unknown };
if (typeof a.name !== 'string' || typeof a.age !== "number") {
return false;
}
return true;
}
```

其中 `const a = v as { name: unknown; age: unknown }` 比较丑, 怎么写才好?
3808 次点击
所在节点    TypeScript
3 条回复
iugo
2019-08-22 19:00:36 +08:00
根据 https://github.com/microsoft/TypeScript/issues/31132 的记录, #21732 'Worth a try, accepting PRs'.

也许现在没什么好的解决办法, 但将来会有吧.
momocraft
2019-08-22 19:03:36 +08:00
把这里的 unknown 改成 any,在获得 unknown 值的地方用 unknown
iugo
2019-08-22 19:14:08 +08:00
@momocraft 在尝试尽量使用 unknown 替代 any 的时候遇到的问题. 本身 any 用得也不多, 主要是传入值. 对于传入值, 转为 unknown 至少从语义上来说还是挺好的. 刚开始尝试.

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://tanronggui.xyz/t/594290

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX