前言


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

原始数据类型包括: Boolean Number String Null Undefined Symbol(ES6 新增)

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


正文


布尔值


布尔值是最基础的数据类型,在 TypeScript 中,使用 boolean 定义布尔值类型。

let isDone: boolen = true;
// 直接调用 Boolean,也可以返回一个 boolean 类型
let createByBoolean: boolean = Boolean(true);


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

let createByNewBoolean: boolean = new Boolean(true);
// 不能将类型“Boolean”分配给类型“boolean”。
//  “boolean”是基元,但“Boolean”是包装器对象。如可能首选使用“boolean”。


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

let createByNewBoolean: Boolean = new Boolean(true);


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


数值


使用 number 定义数值类型:

let decLiteral: number = 6;
let hexLiteral: number = 0xf00d;
let binaryLiteral: number = 0b1010;     // ES6 中二进制表示法
let octalLiteral: number = 0o744;       // ES6 中八进制表示法
let notANumber: number = NaN;
let infinityNumber: number = Infinity;




    


编译结果:

var decLiteral = 6;
var hexLiteral = 0xf00d;
var binaryLiteral = 10; // ES6 中二进制表示法
var octalLiteral = 484; // ES6 中八进制表示法
var notANumber = NaN;
var infinityNumber = Infinity;


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


字符串


使用 string 定义字符串类型:

let myName: string = 'Frankie';
let myAge: number = 20;
let sentence: string = `Hello, I'm ${myName}`;

编译结果:

var myName = 'Frankie';
var myAge = 20;
var sentence = "Hello, I'm " + myName;


空值


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

function showName(): void {
    console.log(`I'm Frankie.`);
}




    


声明一个 void 类型的变量没什么用,因为你只能将它赋值为 undefined null 。(任意值类型也是可以的)

let unusable1: void = undefined;
let unusable2: void = null;


Null 和 Undefined


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

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


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

// 但是要注意,以下这个在 --strictNullChecks  严格空检查模式下,编译会报错。
let num1: number = undefined;
let u: undefined;
let num2: number = u;


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

let u: void;
let num: number = u;
// 编译出错
// Type 'void' is not assignable to type 'number'.


TypeScript入门指南:静态类型检查的优势
TypeScript是一种由微软开发的开源编程语言,它是JavaScript的超集,添加了静态类型检查和其他一些新特性。在前端开发中,JavaScript是最常用的编程语言之一,但由于JavaScript是一种动态类型语言,它在编译时无法捕获所有类型错误,导致在运行时可能出现一些难以调试和潜在的bug。TypeScript的出现解决了这个问题,为JavaScript添加了静态类型检查,使得我们能够在编译时发现潜在的类型错误,从而提高代码的可靠性和可维护性。本文将介绍TypeScript的入门指南,并着重讨论静态类型检查的优势。
TypeScript 入门指南:类型注解、接口和泛型
在现代前端开发中,TypeScript 已经成为越来越受欢迎的选择。TypeScript 是 JavaScript 的超集,它为 JavaScript 提供了类型系统和更多功能,帮助开发者在编码阶段发现潜在的错误,提高代码质量和可维护性。本文将深入探讨 TypeScript 中的核心特性:类型注解、接口和泛型。我们会从基础概念出发,循序渐进地讲解,同时提供丰富的代码示例和注释。
TypeScript提供了JavaScript的所有基本数据类型,如:number、string、boolean等。它还增加了额外的类型,比如any、unknown、never、void等。 number 在TypeScript中,所有的数字都是浮点数。这些数字的类型是number。下面是一些例子: 映射类型(Mapped Types) 映射类型(Mapped Types)是 TypeScript 中一种强大的类型操作工具,它允许我们在编译时转换已知类型的属性,并创建一个新的类型。通过映射类型,我们可以对已有类型的属性进行转换、修改或添加新的属性。这在许多情况下都非常有用,例如将属性变为只读或可选,从现有属性中选择一部分属性等。 映射类型的语法形式为 在 TypeScript 中,类型守卫可以用于在运行时检查变量的类型,并在代码块内部将变量的类型范围缩小到更具体的类型。这种类型收窄可以让 TypeScript 编译器更好地理解我们代码的意图,从而提供更准确的类型推断和类型检查。 TypeScript(一) —— 进阶(TypeScript 中的类型、编译选项及使用 webpack 打包 ts 代码)
TypeScript(一) —— 进阶(TypeScript 中的类型、编译选项及使用 webpack 打包 ts 代码)