最近在看 typescript,看到类型保护不太理解

2018-10-22 14:12:43 +08:00
 caopi

typeof 和 instanceof 为何需要写在函数里面呢

3435 次点击
所在节点    JavaScript
8 条回复
caopi
2018-10-22 14:21:25 +08:00
官方文档里将 typeof x === "number"抽象成一个函数,后面又说不必将他抽象成函数??
caopi
2018-10-22 14:24:37 +08:00
typescript 里面的 typeof 和 js 里面有什么区别吗
ltoddy
2018-10-22 14:31:48 +08:00
首先啊, typescript 是强类型的, 也就是每个变量他的类型是知道的, 或者你声明变量的类型, 或者通过 typescript 的类型推导, 每个变量有明确的类型, 那么类型你都知道, typeof 一个变量不就是有毛病嘛.

借用官网教程的一段代码:

```
function reverse(x: number): number;
function reverse(x: string): string;
function reverse(x: number | string): number | string {
if (typeof x === 'number') {
return Number(x.toString().split('').reverse().join(''));
} else if (typeof x === 'string') {
return x.split('').reverse().join('');
}
}
```

这里用了 typeof, 是为了函数重载.
maichael
2018-10-22 14:34:11 +08:00
@ltoddy typescript 并不是强类型,只是静态类型。
maichael
2018-10-22 14:43:14 +08:00
实际上文档里面说的重点在于静态类型推导这一问题,在函数 padLeft 里,padding 是 string 或者 number 类型,如果 typescript 没有足够的智能识别变量的类型,比如它即便通过了 if(typeof padding === "number"),它仍旧认为 padding 是 string|number 类型,那么 Array(padding + 1).join(" ") + value 就会有问题。所以需要通过 x is number 来将 padding 转化成 number,但 typescript 足够智能,所以不会有这问题。
maichael
2018-10-22 14:47:48 +08:00
在 typescript 里面,typeof 分成两种情况,取决于值的用途。
1. 作为变量使用,比如 const t = typeof A
2. 作为类型使用,比如 type t = typeof A
第一个和普通的 javascript 的 typeof 没有任何区别,第二个是 typescript 里的类型。
kingwl
2018-10-22 14:57:40 +08:00
其实是两个部分
1. type narrow (比如 typeof xxx === 'number' 和其他一大堆情况 )
就是做类型推断
2. type predicate (比如 xxx is Type)
这个是允许一些你 type narrow 不过去的情况下, 自己断言一些类型
caopi
2018-10-22 15:32:56 +08:00
@maichael 明白了,谢谢

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

https://www.v2ex.com/t/499835

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

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

© 2021 V2EX