美文网首页TypeScript
TS 之原始数据类型

TS 之原始数据类型

作者: 越前君 | 来源:发表于2020-04-03 01:25 被阅读0次

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

原始数据类型包括:BooleanNumberStringNullUndefinedSymbol(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 中的构造函数,其他基本类型一样(除了 nullundefined),不再赘述。

数值

使用 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;

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

字符串

使用 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 类型的变量没什么用,因为你只能将它赋值为 undefinednull。(任意值类型也是可以的)

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

Null 和 Undefined

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

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

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

// 但是要注意,以下这个在 --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'.

下一篇介绍任意值。

The end.

相关文章

  • TS 之原始数据类型

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

  • TS基础(一) 变量声明

    ts的类型主要包括两种数据类型:原始数据和对象数据类型原始的数据类型和js的数据类型相似包含以下几种:布尔值 数值...

  • TypeScript02--基础数据类型与接口

    基础数据类型: 1.ts的基础数据类型: ts相比js新增的数据类型:元组,any,void,neve...

  • Typescript - 基础(二)

    TS 的基本类型和枚举类型 1、TS 的数据类型和 ES6 的数据类型 共有数据类型: Boolean Numbe...

  • JAVA的数据类型

    JAVA的数据类型主要分为,原始数据类型和非原始数据类型。原始数据类型就是JAVA自带的一些数据类型,非原始数据类...

  • JS基础 之最新8种数据类型(原始数据类型和引用数据类型)

    一、JS数据类型分为两类原始数据类型和引用数据类型 二、原始数据类型 javascript 的原始数据类型有七种,...

  • TypeScript基本数据类型

    在TS中可以写成以上形式,但不标准。TS内明确控制数据类型。正确写法如下:

  • js数据类型的判断

    一、javascript的数据类型 js数据分为两种类型:原始数据类型(基本数据类型)和引用数据类型。原始数据类型...

  • 数据类型

    typescript 命令 ​ tsc --init 生成配置文件 ts的基础数据类型 特殊数据类型 数组 ...

  • js深度克隆

    在JAVAScript中数据类型分为两种,一种是原始数据类型,另外一种就是引用数据类型。 数据类型 原始数据类型:...

网友评论

    本文标题:TS 之原始数据类型

    本文链接:https://www.haomeiwen.com/subject/qmgqphtx.html