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

2019 年 8 月 22 日
 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 }` 比较丑, 怎么写才好?
4334 次点击
所在节点    TypeScript
3 条回复
iugo
2019 年 8 月 22 日
根据 https://github.com/microsoft/TypeScript/issues/31132 的记录, #21732 'Worth a try, accepting PRs'.

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

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

https://v2ex.xtra.eu.org/t/594290

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

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

© 2021 V2EX