Typescript入门手册之基本类型在TypeScript中的应用
Posted 余光、
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Typescript入门手册之基本类型在TypeScript中的应用相关的知识,希望对你有一定的参考价值。
Ts基础入门(一)基本类型在TypeScript中的应用。
TypeScript 是添加了类型系统的 javascript,适用于任何规模的项目。
TypeScript 可以和 JavaScript 共存,这意味着 JavaScript 项目能够渐进式的迁移到 TypeScript。
相信大家经常会问到为什么会有Ts,我该不该学习Ts,在知乎上这样的问题也会受到大家广泛的关注,而我的回答是,该去了解,因为了解Ts不会像我们学习英语那样“痛苦”,如果TypeScript能够解决你的问题,那就继续深入的学习吧,本系列的第一篇文章也不会有太深奥的理论,花一些时间了解一下给出自己的判断吧~
话不多说,我们先来从基本类型入手,走进Ts的大门!系列文章,收藏不走丢哦
一、原始数据类型
JavaScript的类型分为两种:原始数据类型和对象类型。
原始数据类型包括:
- 布尔值
- 数值
- 字符串
- null
- undefined
- 以及 ES6 中的新类型 Symbol 和 ES10 中的新类型 BigInt。
1.1 布尔值
布尔值是最基础的数据类型,在TypeScript中,使用boolean
定义布尔值类型:
let visible: boolean = false;
注意;在TypeScript中,boolean
是JavaScript中的基本类型,而Boolean
是JavaScript中的构造函数。
1.2 数值
使用number来定义数值类型:
let age: number = 100;
1.3 字符串
使用string
来定义字符串类型:
const name: string = '余光';
const templateName = `hi ${name}!`
1.4 空值
JavaScript没有空值(Void)的概念,在TypeScript中,可以用void
表示没有任何返回值的函数:
function alertName(): void {
alert('My name is Tom');
}
声明一个void
类型的变量没有什么用,因为你只能将它赋值为undefined和null:
let unusable: void = 1;
1.5 Null 和 Undefined
在 TypeScript 中,可以使用 null 和 undefined 来定义这两个原始数据类型:
let u: undefined = undefined;
let n: null = null;
与 void 的区别是,undefined 和 null 是所有类型的子类型。也就是说undefined类型的变量,可以赋值给number类型的变量:
// 严格模式下,会报错
let num: number = undefined;
// 这样也不会报错
let u: undefined;
let num: number = u;
注意
- 声明变量的数据类型为 void 时,非严格模式下,变量的值可以为 undefined 或 null。而严格模式下,变量的值只能为 undefined。
- 严格模式下:
let num: number = undefined;
会报错
二、任意值
任意值Any
用来表示允许赋值为任意类型。
先来看下面的代码
let age:number = 100;
age = '余光'
类型检测会提前帮我们规避一些不必要的风险,大家在平时也一定会遇到类型不匹配这样的错误,如果是any
类型,则允许被赋值为任意类型。
let age:any = 100;
age = '余光'
2.1 任意值的属性和方法
在任意值上访问任何属性都是允许的:
let anyThing: any = 'todo';
console.log(anyThing.myName);
console.log(anyThing.myName.firstName);
也允许调用任何方法:
let anyThing: any = '余光';
anyThing.toString();
可以认为,声明一个变量为任意值之后,对它的任何操作,返回的内容的类型都是任意值。
2.2 未声明类型的变量
变量如果在声明的时候,未指定其类型,那么它会被识别为任意值类型:
let something;
something = 'str';
something = 7;
something.name = '余光';
// 等价于
let something: any;
something = 'str';
something = 7;
something.name = '余光';
2.3 注意
经过前面两点(尤其是第二点)的描述,你会发现如果给变量添加了any
的声明,那么Typescript就变成了Anyscript了,那岂不是一夜回到了解放前?
理论上我们尽量不使用any,就好像才出现了const和let之后,我们进来避免试用var一样。
三、类型推论
如果没有明确的指定类型,那么TypeScript会依照类型推论(Type Inference)的规则推断出一个类型。
先来看看下面的代码:
let age = 100;
age = '余光'; // 不能将类型“string”分配给类型“number”
这是因为Ts会在没有明确指定类型的时候,根据赋值时数据类型推测出一个指定类型,这就是类型推论。
注意
如果定义的时候没有赋值,不管之后有没有赋值,都会被推断成any
类型而完全不被类型检查。
四、联合类型
联合类型(Union Types)表示取值可以为多种类型中的一种。
第一、二小节提到了基本类型的怎么指定的,如果你希望一个变量的类型是可选的可以试用any,但还有更好的方式就是明确指定几个类型——联合类型
let category: string | number;
category = 'seven';
category = 7;
category = true; // 不能将类型“boolean”分配给类型“string | number”。
联合类型使用 | 分隔每个类型。表示允许设置的类型
注意
当TypeScript不确定一个联合类型的变量到底是哪个类型的时候,我们只能访问此联合类型的所有类型里共有的属性或方法:
function getLength(something: string | number): number {
return something.length;
}
联合类型的变量在被赋值的时候,会根据类型推论的规则推断出一个类型,所以也会遇到上面问题
let val: string | number;
val = 'seven';
console.log(val.length); // 5
val = 7;
console.log(val.length); // 类型“number”上不存在属性“length”
此时如果你细心,你会发现:val是联合类型,而不会因为赋值而导致type类型变化
写在最后
本篇文章是《Typescript基础入门》第一篇,到这里就结束了,主要带大家了解一下基本类型在Ts中的表现,你看绝大部分概念我们都可以吸收,写起来虽然会有些别扭,但也不是特别难以接受,会不会更有信心了解下去了!我们共勉~
下一篇文章我们来聊一聊引用(对象、数组)类型在Ts中又会有什么不同呢?
- 花名:余光
- WX:j565017805
- 邮箱:webbj97@163.com
其他沉淀
以上是关于Typescript入门手册之基本类型在TypeScript中的应用的主要内容,如果未能解决你的问题,请参考以下文章
Typescript入门手册之引用类型在TypeScript中的应用
Typescript入门手册之引用类型在TypeScript中的应用
Typescript 入门手册之函数类型在 TypeScript 中的应用