TypeScript 类型转换

在处理类型时,有时需要重写变量的类型,例如当库提供了错误的类型时。

类型转换就是重写类型的过程。

使用 as 进行类型转换

一种直接的类型转换方法是使用 as 关键字,这将直接改变给定变量的类型。

实例

let x: unknown = 'hello';
console.log((x as string).length);

亲自试一试

类型转换实际上并不会改变变量内部数据的类型,例如,以下代码将无法按预期工作,因为变量 x 仍然包含一个数字。

let x: unknown = 4;
console.log((x as string).length); // 打印 undefined,因为数字没有长度

TypeScript 仍然会尝试进行类型检查以防止看似不正确的类型转换,例如,以下将抛出类型错误,因为 TypeScript 知道在不转换数据的情况下,将字符串转换为数字是没有意义的:

console.log((4 as string).length);
// 错误:将类型“number”转换为类型“string”可能是一个错误,因为两种类型之间没有足够的重叠。如果这是有意的,请首先将表达式转换为“unknown”。

下面的“强制类型转换”部分介绍了如何重写这一点。

使用 <> 进行类型转换

使用 <> 与使用 as 进行类型转换的效果相同。

实例

let x: unknown = 'hello';

console.log((<string>x).length);

亲自试一试

这种类型的类型转换在 TSX 中不起作用,例如在处理 React 文件时。

强制类型转换

为了重写 TypeScript 在进行类型转换时可能抛出的类型错误,请首先将类型转换为 unknown,然后再转换为目标类型。

实例

let x = 'hello';
console.log(((x as unknown) as number).length); // x 实际上不是一个数字,所以这将返回 undefined

亲自试一试