8. TypeScript 类型推论和类型断言

2024-04-09 13:44

本文主要是介绍8. TypeScript 类型推论和类型断言,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

类型推论

在TypeScript 中,有很多时间并不需要显式地指定变量的类型,TypeScript的一大优势是它的类型推论机制,可以自动推断变量、函数参数和返回值的类型,从而减少了手动类型注解的需求。

变量类型推论

TypeScript 可以根据变量的初始值推断出变量的类型。例如:

let x = 3; // x 被推断为 number 类型
let y = "hello"; // y 被推断为 string 类型

如果没有初始值,TypeScript 会将变量推断为 any 类型。

let z; // z 被推断为 any 类型

函数参数类型推论

TypeScript 可以根据函数参数的默认值推断出参数的类型。例如:

function greet(name = "world") {console.log(`Hello, ${name}!`);
}

在上面的例子中,TypeScript 会推断 name 参数的类型为 string

函数返回值类型推论

TypeScript 可以根据函数体中的代码推断出函数的返回值类型。例如:

function add(a: number, b: number) {return a + b;
}

在上面的例子中,TypeScript 会推断 add 函数的返回值类型为 number

类型断言

在 TypeScript 中,类型断言(Type Assertion)是一种告诉编译器变量的具体类型的方式。它允许你覆盖 TypeScript 的类型推断,如果你能明确变量的类型,就可以手动指定一个值的类型。

1. TypeScript 类型断言有两种语法形式:

// 尖括号语法
let someValue: any = "this is a string";
let strLength: number = (<string>someValue).length;// as 语法
let someValue: any = "this is a string";
let strLength: number = (someValue as string).length;

两种形式是等价的,但在 JSX 中只能使用 as 语法。

2. 常见用例

2.1 将一个联合类型断言为其中一个类型

当 TypeScript 不确定一个联合类型的变量到底是哪个类型时,我们只能访问此联合类型的所有类型中共有的属性或方法。如果需要访问特定类型的属性或方法,就需要使用类型断言。

function getLength(something: string | number): number {if ((<string>something).length) {return (<string>something).length;} else {return something.toString().length;}
}

2.2 将一个父类断言为更加具体的子类

当我们需要访问子类特有的属性或方法时,可以使用类型断言将父类断言为子类。

class ApiError extends Error {code: number = 0;
}
class HttpError extends Error {statusCode: number = 200;
}function isApiError(error: Error) {if (typeof (error as ApiError).code === 'number') {return true;}return false;
}

2.3 将任意类型断言为 any

在某些情况下,我们可能需要临时绕过类型检查。可以使用 as any 将一个变量断言为 any 类型。

let someValue: string = "this is a string";
let strLength: number = (someValue as any).length;

2.4 非空类型断言

非空类型断言 ! 是类型断言的一种形式,它用于确保一个值不是 null 或 undefined。格式为在变量前面加上!

function printMessage(message?:string){console.log(message!.length); /**因为message是可选参数,如果为undefined,编译会不通过,加上非空类型断言,**/
}

但是,滥用 any 类型可能导致类型检查失效,应谨慎使用。有时候不能直接进行类型断言,可能需要断言成any,再断言成其它类型。

3. 注意事项

3.1 类型断言不是类型转换

类型断言只是一种告诉编译器如何理解代码的方式,并不会真正影响变量的类型。

3.2 类型断言与类型声明的区别

类型断言和类型声明都可以指定变量的类型,但类型声明更加严格,会在编译阶段进行类型检查。而类型断言只在编译阶段起作用,不会影响运行时的类型。

// 类型声明
let someValue: string = "this is a string";// 类型断言
let someValue: any = "this is a string";
let strLength: number = (<string>someValue).length;

3.3 避免滥用类型断言

过度使用类型断言可能掩盖潜在的类型错误,降低代码的可维护性。应该尽量让 TypeScript 自动推断类型,只在必要时使用类型断言。

4. 总结

TypeScript 类型断言是一种强大的工具,允许我们手动指定变量的类型。合理使用类型断言可以提高代码的灵活性和可读性。但同时也要注意避免滥用,以免损失 TypeScript 静态类型检查的优势。

这篇关于8. TypeScript 类型推论和类型断言的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/888305

相关文章

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

Python如何查看数据的类型

《Python如何查看数据的类型》:本文主要介绍Python如何查看数据的类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python查看数据的类型1. 使用 type()2. 使用 isinstance()3. 检查对象的 __class__ 属性4.

Python容器类型之列表/字典/元组/集合方式

《Python容器类型之列表/字典/元组/集合方式》:本文主要介绍Python容器类型之列表/字典/元组/集合方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 列表(List) - 有序可变序列1.1 基本特性1.2 核心操作1.3 应用场景2. 字典(D

Python如何在Word中生成多种不同类型的图表

《Python如何在Word中生成多种不同类型的图表》Word文档中插入图表不仅能直观呈现数据,还能提升文档的可读性和专业性,本文将介绍如何使用Python在Word文档中创建和自定义各种图表,需要的... 目录在Word中创建柱形图在Word中创建条形图在Word中创建折线图在Word中创建饼图在Word

SpringBoot接收JSON类型的参数方式

《SpringBoot接收JSON类型的参数方式》:本文主要介绍SpringBoot接收JSON类型的参数方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、jsON二、代码准备三、Apifox操作总结一、JSON在学习前端技术时,我们有讲到过JSON,而在

Rust中的BoxT之堆上的数据与递归类型详解

《Rust中的BoxT之堆上的数据与递归类型详解》本文介绍了Rust中的BoxT类型,包括其在堆与栈之间的内存分配,性能优势,以及如何利用BoxT来实现递归类型和处理大小未知类型,通过BoxT,Rus... 目录1. Box<T> 的基础知识1.1 堆与栈的分工1.2 性能优势2.1 递归类型的问题2.2

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

Redis的Zset类型及相关命令详细讲解

《Redis的Zset类型及相关命令详细讲解》:本文主要介绍Redis的Zset类型及相关命令的相关资料,有序集合Zset是一种Redis数据结构,它类似于集合Set,但每个元素都有一个关联的分数... 目录Zset简介ZADDZCARDZCOUNTZRANGEZREVRANGEZRANGEBYSCOREZ

IDEA如何将String类型转json格式

《IDEA如何将String类型转json格式》在Java中,字符串字面量中的转义字符会被自动转换,但通过网络获取的字符串可能不会自动转换,为了解决IDEA无法识别JSON字符串的问题,可以在本地对字... 目录问题描述问题原因解决方案总结问题描述最近做项目需要使用Ai生成json,可生成String类型