基本数据类型
#
let isDone: boolean = false;
#
let amount: number = 6;
字符串#
-
类型
-
模板字符串
-
支持换行
-
支持内嵌表达式
-
-
和 JavaScript 一样,可以使用双引号,也可以使用单引号,推荐单引号
let nickname: string = '张三';
还可以使用模板字符串(换行 + 嵌入表达式):
let nickname: string = `Gene`; let age: number = 37; let sentence: string = `Hello, my nickname is ${ nickname }. I'll be ${ age + 1 } years old next month.`;
数组#
TypeScript像JavaScript一样可以操作数组元素。 有两种方式可以定义数组。 第一种,可以在元素类型后面接上[]
let list: number[] = [1, 2, 3];
let list: Array<number> = [1, 2, 3];
元组#
元组类型允许表示一个已知元素数量和类型的数组,各元素的类型不必相同。 比如,你可以定义一对值分别为string
和number
类型的元组。
// Declare a tuple type let x: [string, number]; // Initialize it x = ['hello', 10]; // OK // Initialize it incorrectly x = [10, 'hello']; // Error
Object#
-
允许赋任意值
-
但是不能调用任意方法,即便它真的有
let foo: Object = { name: 'Jack', age: 18 }
注意:知道即可,用的很少,没有类型校验和语法提示
Any#
有时候,我们会想要为那些在编程阶段还不清楚类型的变量指定一个类型。 这些值可能来自于动态的内容,比如来自用户输入或第三方代码库。 这种情况下,我们不希望类型检查器对这些值进行检查而是直接让它们通过编译阶段的检查。 那么我们可以使用 any
类型来标记这些变量:
let notSure: any = 4; notSure = "maybe a string instead"; notSure = false; // okay, definitely a boolean
Void#
void
类型像是与any
类型相反,它表示没有任何类型。 当一个函数没有返回值时,你通常会见到其返回值类型是 void
:
function warnUser(): void { alert("This is my warning message"); }
let unusable: void = undefined;
Null 和 Undefined#
和 void
相似,它们的本身的类型用处不是很大:
// Not much else we can assign to these variables! let u: undefined = undefined; let n: null = null;
默认情况下null
和undefined
是所有类型的子类型。 就是说你可以把 null
和undefined
赋值给number
然而,当你指定了--strictNullChecks
标记,null
和 undefined
只能赋值给 void
和它们各自声明的变量。 这能避免 很多常见的问题。许在某处你想传入一个 string
或null
或undefined
,你可以使用联合类型string | null | undefined
。
类型推断#
有时候你会遇到这样的情况,你会比TypeScript更了解某个值的详细信息。 通常这会发生在你清楚地知道一个实体具有比它现有类型更确切的类型。
通过类型断言这种方式可以告诉编译器,“相信我,我知道自己在干什么”。 类型断言好比其它语言里的类型转换,但是不进行特殊的数据检查和解构。 它没有运行时的影响,只是在编译阶段起作用。 TypeScript会假设你,程序员,已经进行了必须的检查。
类型断言有两种形式。 其一是“尖括号”语法:
let someValue: any = "this is a string"; let strLength: number = (<string>someValue).length;
let someValue: any = "this is a string"; let strLength: number = (someValue as string).length;
其它#
只读数组:
-
ReadonlyArray<T>
去除了数组的所有可变方法,确保数组创建后再也不能被修改
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
2020-03-19 数据库读写分离之配置Django实现数据库读写分离