仰天大笑出门去,我辈岂是蓬蒿人。这篇文章主要讲述#yyds干货盘点# 系统学习 TypeScript——基础类型相关的知识,希望能为你提供帮助。
文章图片
前言TypeScript 包含的基础类型总结起来有:
- 布尔值
- 数字
- 字符串
- 数组
- 元组
- 枚举
- 任意值
- 空值
- Null 和 undefined
- Never
- Object
布尔值 → boolean它只有两个值——true 和 false。
let isNew: boolean = true;
数字 → numberTypeScript 中的整形和浮点数类型都是 number,这点和javascript 是一样的,比如:十进制、二进制、八进制和十六进制的类型都是 number。
let decAge: number = 22;
let hexAge: number = 0x0016;
let binaryAge: number = 0b10110;
let octalAge: number = 0o026;
// 以上变量使用 (number).toString(10) 转换为十进制都为 22
字符串 → string和 javaScript 一样,字符串的值使用单引号或者双引号包裹:
let myName: string = "编程三昧";
let myHomepage: string = `example.com/$myName`;
数组TypeScript 中定义数组的方式有两种。
第一种是元素类型后面接上
[]
,表示由此类型元素组成的一个数组:let arr: number[] = [1, 2, 3, 4];
// 如果在数组中加入其他元素会报错
第二种是使用数组泛型定义数组:
let arr1: any[] = [1, "2", 3, "4"];
// 这个数组中可以假如任意类型的元素
元组 Tuple元组类型允许表示一个已知元素数量和类型的数组,各元素的类型不必相同。
let arr2:[number, string, number] = [1,"2",3];
// 若果写成 [1,2,3] 会报错
元素是严格规定了数组的长度和每个位置的元素类型,并且在赋值时需要严格对应,否则会报错。
枚举
enum
类型是对JavaScript标准数据类型的一个补充。 像C#等其它语言一样,使用枚举类型可以为一组数值赋予友好的名字。enum Color Red, Green, Blue
let c: Color = Color.Green;
默认情况下,从
0
开始为元素编号。 你也可以手动地指定成员的数值。 例如,我们将上面的例子改成从 1
开始编号:enum Color Red = 1, Green, Blue
let c: Color = Color.Green;
或者,全部都采用手动赋值:
enum Color Red = 1, Green = 2, Blue = 4
let c: Color = Color.Green;
枚举类型提供的一个便利是你可以由枚举的值得到它的名字。 例如,我们知道数值为2,但是不确定它映射到Color里的哪个名字,我们可以查找相应的名字:
enum Color Red = 1, Green, Blue
let colorName: string = Color[2];
console.log(colorName);
// 显示Green因为上面代码里它的值是2
任意值 any代表任意类型的值。如果不希望类型检查器对这些值进行检查而是直接让它们通过编译阶段的检查。,那么就可以使用
any
类型来标记这些变量:let a: any = 12;
a = "12";
let list: any[] = [1, true, "free"];
list[1] = 100;
空值 void当一个数据没有任何类型时,通常用 void 标记,多用于函数返回值。
function sayName(): void
console.log(`My name is 编程三昧。`);
let aNull: void = null;
let aNull1: void = undefined;
null 和 undefinedTypeScript 中也有 null 和 undefined 两种类型,它们只能各自对应 null 值和 undefined 值。
let theNull: null = null;
let theUndefined: undefined = undefined;
这两个类型基本上没啥大的用处。
Never
never
类型表示的是那些永不存在的值的类型。 例如, never
类型是那些总是会抛出异常或根本就不会有返回值的函数表达式或箭头函数表达式的返回值类型; 变量也可能是 never
类型,当它们被永不为真的类型保护所约束时。never
类型是任何类型的子类型,也可以赋值给任何类型;然而,没有类型是never
的子类型或可以赋值给never
类型(除了never
本身之外)。 即使 any
也不可以赋值给never
。下面是一些返回
never
类型的函数:// 返回never的函数必须存在无法达到的终点
function error(message: string): never
throw new Error(message);
// 推断的返回值类型为never
function fail()
return error("Something failed");
// 返回never的函数必须存在无法达到的终点
function infiniteLoop(): never
while (true)
object【#yyds干货盘点# 系统学习 TypeScript——基础类型】object 类型包含除了几种基本类型之外的所有类型。
let obj: object = [1,2,3];
let obj1: object =
name: "编程三昧"
;
let func: object = ()=>
console.log("编程三昧");
扩展1、TypeScript 会根据你给变量的初始值判断默认类型。
let aNum = 12;
aNum = "number";
// Type string is not assignable to type number.
2、函数方法的参数和返回值都可以使用类型限制,保证传参和返回值的正确性。
function sum(a: number, b:number): number
return a + b;
sum(1, "3");
// Argument of type string is not assignable to parameter of type number.
总结以上就是 TypeScript 中的基础数据类型介绍,总结起来就是:
- 在变量(函数的括号)后面添加冒号,后面跟上期望的类型,即可限制类型的前后一致性;
- 如果没有显式的添加类型限制,TypeScript 会根据初始值自动添加类型。
~ 本文完,感谢阅读!
~
推荐阅读
- 什么是CI/CD(不明白?一文教会你企业级CI/CD核心理论概念 #yyds干货盘点#)
- #yyds干货盘点#一个简单的websocket示例
- #yyds干货盘点#ABAP新语法
- Flutter 专题75 图解基本 TabBar 标签导航栏#yyds干货盘点#
- #yyds干货盘点# SAP 移动开发技术综述
- RT-Thread快速入门-初探RT-Thread
- Windows8系统桌面图标无法拖动怎样办
- Win8系统在英国的占有率已超过xp系统
- 图文 关闭Win8 Modern UI应用的办法