TypeScript学习总结之基础类型
对 TypeScript 的认识
TypeScript 是什么?
TypeScript 是 JavaScript 的超集,他扩展了 JavaScript 的语法,所以任何现有的 JavaScript 程序可以不加改变的在 TypeScript 下工作
TypeScript 是开发大型应用的基石。
TypeScript 提供了更丰富的语法提示, 在编写阶段能够检查错误。
与 JavaScript 的区别
TypeScript 是静态类型, JavaScript 是动态类型
- 在 TypeScript 中 类型是确定好的。(一旦给类型赋值后就不能更改其类型)
TypeScript 数据类型
为了让程序有价值,我们需要能够处理最简单的数据单元:数字,字符串,结构体,布尔值等。 TypeScript 支持与 JavaScript 几乎相同的数据类型,此外还提供了实用的枚举类型方便我们使用。
JavaScript 的基本数据类型:
原始数据类型:string、number、boolean、null、undefined、symbol
引用数据类型:object
TypeScript 的基本数据类型:
包含 JavaScript 所有的基本数据之外,额外新增了几种新的数据类型(大概的写一下):
- any(任意类型)、
- never (
never
类型表示的是那些永不存在的值的类型) 、 - void(
void
类型像是与any
类型相反、只能为它赋予undefined
和null
) - 针对于对象类型的: interface
- 针对于数组的:number[] 、string[] 、boolean[] 等, 泛型的写法:Array<元素类型> (Array
) - 函数的注解
TypeScript 原始数据的注解
布尔值的注解 :
1 |
|
//注意 boolean 首字母不能大写
数字的注解:
1 |
|
字符串的注解:
1 |
|
// 注意这点不能用 name 来命名
any 数据类型: 任意数据类型;
如果是不同变量的话,可以是任意的数据类型
1
2
3let notSure: any = 4;
notSure = 'maybe a string instead';
notSure = false; // okay, definitely a boolean如果是对象的话, any 是不能够提示原型上的共有属性和方法的。
1
2
3let notSure: any = 4;
notSure.ifItExists(); // okay, ifItExists might exist at runtime
notSure.toFixed(); // okay, toFixed exists (but the compiler doesn't check)相反,如果是 Object 的话,它就会提示使用 Object 类型上的属性
1
2
3let prettySure: Object = 4;
prettySure.toFixed(); // Error: Property 'toFixed' doesn't exist on type 'Object'.
prettySure.toString(); // OK未给初始值的变量类型 为 any 类型
1
2
3let a;
a = '123';
a = 123;
void
void
类型像是与
any类型相反,它表示没有任何类型。 当一个函数没有返回值时,你通常会见到其返回值类型是
void
1 |
|
null & undefined
默认情况下 null 和 undefined 是所有类型的子类型
在 tsconfig.json 中配置 strictNullChecks = false 时,
就可证明 null 和 undefined 是所有类型的子类型
1 |
|
但官方建议让我们 strictNullChecks = true ,但在配置中这个标记是关闭的。
Never
never
类型表示的是那些永不存在的值的类型, 例如, never
类型是那些总是会抛出异常或根本就不会有返回值的函数表达式或箭头函数表达式的返回值类型; 变量也可能是 never
类型,当它们被永不为真的类型保护所约束时。
(目前我接触的这种实际情景不多,以后遇到了我再去单独了解)
Object
object 表示非原始类型,也就是除 number,string,boolean,symbol,null 或 undefined 之外的类型。
1 |
|
以上是官网的例子, 上面代码说明了 object 不能是去使用 原始类型 , 比如create(function(){})
、 create([])
这些是可以 OK 的。
类型注解 & 类型推论 & 联合类型
在我们定义变量时,而这个变量是原始数据,那么,我们不需要对它进行类型注解,它也能推论出该变量属于什么类型的。
所以正常情况下,能够做出类型推论的话,我们专门去对它注解,会显得有些繁琐了。
但是肯定有别的情况需要我们去做类型注解,
比如:当我们定义一个方式, 它会提示我们去进行类型注解
1 |
|
做类型注解:
1 |
|
联合类型: 多个类型当中,我们可以选择其中类型的一种
1 |
|
而当我们去定义一个函数时:
1 |
|
因此,我们要注意,
联合类型的共有属性不会报错,
但不要用 联合类型中其中一种类型的独有属性 比如 String 中的 split 方法, Number 是没有此属性的, 因此会报错
在赋值的时候要确认类型
初识 interface
接口的作用就是为这些类型命名和为你的代码或第三方代码定义契约。
- 对对象的形状进行描述;
- 对类的一部分行为的抽象;
简单使用:(对 对象的形状进行描述)
// interface 默认不能多属性也不能少属性
1 |
|
- 可选属性:如果偏偏少属性呢? 就在属性后边加
?
即可。 如果想多属性呢, - 任意/多选 属性
[propName:string]:any
- 只读属性:
readonly
后面加属性
1 |
|
数组注解
定义数组的方式有三种:
- 类型[] 如: number[]
- 数组泛型 Array<类型> 如: Array
- interface 方式
类型[]
1 |
|
Array<类型>
1 |
|
interface 方式
1 |
|
1 |
|
类数组
// args 就是个类数组
本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!