Skip to content

TS基础

原始数据类型介绍

TypeScript是强类型语法,它的目的是让代码逻辑更加严谨,规范,这一特性要求用户在书写代码时,在变量、函数参数和返回值等地方显示地注明类型,从而使代码更易于理解和维护。

同时TypeScript编译器具有类型检测和类型推导的功能,前者会对代码进行类型检测,发现类型错误和潜在的逻辑错误,减少运行时的错误和调试时间,后者则是编译器会根据代码上下文,自动推断变量或表达式的类型,减少冗余的类型注解,提高代码的可读性和简洁性。

JavaScript 的类型分为两种:原始数据类型(Primitive data types)和对象类型(Object types)。

原始数据类型包括:布尔值、数值、字符串、nullundefined 以及 ES6 中的新类型 Symbol 和 ES10 中的新类型 BigInt

本节主要介绍前五种原始数据类型在 TypeScript 中的应用。

布尔值

最基本的数据类型就是简单的true/false值,在JavaScript和TypeScript里叫做boolean(其它语言中也一样)。

typescript
//定义Typescript的boolean 类型
let isDone: boolean = false;
console.log("typeof(isDone) ",typeof(isDone));
// 编译通过
// 后面约定,未强调编译错误的代码片段,默认为编译通过

注意,使用构造函数 Boolean 创造的对象不是布尔值:

typescript
let createdByNewBoolean: boolean = new Boolean(1);

//TSError: ⨯ Unable to compile TypeScript:
//boolean.ts(1,5): error TS2322: Type 'Boolean' is not assignable to type '//boolean'.
//  'boolean' is a primitive, but 'Boolean' is a wrapper object. Prefer using 'boolean' when possible.

事实上 new Boolean() 返回的是一个 Boolean 对象:

typescript
let createdByNewBoolean: Boolean = new Boolean(1);

直接调用 Boolean 也可以返回一个 boolean 类型:

typescript
let createdByBoolean: boolean = Boolean(1);

在 TypeScript 中,boolean 是 JavaScript 中的基本类型,而 Boolean 是 JavaScript 中的构造函数。其他基本类型(除了 nullundefined)一样,不再赘述。

数值

使用 number 定义数值类型:

typescript

let decLiteral: number = 6;
console.log('decLiteral ',decLiteral);

//十六进制
let hexLiteral: number = 0xf00d;
console.log('hexLiteral ',hexLiteral);

// ES6 中的二进制表示法
let binaryLiteral: number = 0b1010;
console.log('binaryLiteral ',binaryLiteral);

// ES6 中的八进制表示法
let octalLiteral: number = 0o744;
console.log('octalLiteral ',octalLiteral);

//非数字,注意NaN关键字还是number类型 
let notANumber: number = NaN;
console.log('typeof(NaN) ',typeof(NaN));

console.log('notANumber ',notANumber);

//无穷大
let infinityNumber: number = Infinity;
console.log('infinityNumber ',infinityNumber);
javascript
"use strict";
let decLiteral = 6;
console.log('decLiteral ', decLiteral);
//十六进制
let hexLiteral = 0xf00d;
console.log('hexLiteral ', hexLiteral);
// ES6 中的二进制表示法
let binaryLiteral = 0b1010;
console.log('binaryLiteral ', binaryLiteral);
// ES6 中的八进制表示法
let octalLiteral = 0o744;
console.log('octalLiteral ', octalLiteral);
//非数字,注意,NaN关键字还是number类型 
let notANumber = NaN;
console.log('typeof(NaN) ', typeof (NaN));
console.log('notANumber ', notANumber);
//无穷大
let infinityNumber = Infinity;
console.log('infinityNumber ', infinityNumber);
typescript
//输出结果
decLiteral  6
hexLiteral  61453
binaryLiteral  10
octalLiteral  484
typeof(NaN)  number
notANumber  NaN
infinityNumber  Infinity

其中 0b10100o744ES6 中的二进制和八进制表示法,它们会被编译为十进制数字。

字符串

使用 string 定义字符串类型:

typescript
let heroName: string = 'Tom';
let myAge: number = 25;

// 模板字符串
let sentence: string = `Hello, my name is ${heroName}.
I'll be ${myAge + 1} years old next month.`;

console.log(sentence);
javascript
"use strict";
let heroName = 'Tom';
let myAge = 25;
// 模板字符串
let sentence = `Hello, my name is ${heroName}.
I'll be ${myAge + 1} years old next month.`;
console.log(sentence);

其中 ``` 用来定义 ES6 中的模板字符串${expr} 用来在模板字符串中嵌入表达式。

空值

JavaScript 没有空值(Void)的概念,在 TypeScript 中,可以用 void 表示没有任何返回值的函数:

ts
function alertName(): void {
    alert('My name is Tom');
}

声明一个 void 类型的变量没有什么用,因为你只能将它赋值为 undefinednull(只在 --strictNullChecks 未指定时):

ts
let unusable: void = undefined;

Null 和 Undefined

在 TypeScript 中,可以使用 nullundefined 来定义这两个原始数据类型:

ts
let u: undefined = undefined;
let n: null = null;

void 的区别是,undefinednull 是所有类型的子类型。也就是说 undefined 类型的变量,可以赋值给 number 类型的变量:

ts
// 这样不会报错
let num: number = undefined;
// 这样也不会报错
let u: undefined;
let num: number = u;

void 类型的变量不能赋值给 number 类型的变量:

ts
let u: void;
let num: number = u;

// Type 'void' is not assignable to type 'number'.

VS Code工具提示如下:

image-20240203103733018

Released under the MIT License.