typescript的数据类型分为如下布尔值——boolean数字——number字符串——string数组——Array元组——Tuple枚举——enumAnyvoidNull和UndefinedneverObject布尔值——boolean布尔值是最简单的数据类型有两个值true/false在JavaScript和TypeScript的里面一样// boolean变量的声明 let isDone: boolean true; console.log(isDone); // true // 类型转换 let numberBoolean1:number Number(isDone); let numberBoolean2:number Number(!isDone); // boolean装换成数字 true 1; false 0; console.log(numberBoolean1); // 1 console.log(numberBoolean2); // 0 let stringBoolean: string String(isDone); console.log(stringBoolean); // true // 类型判断 console.log(typeof(isDone)); // boolean数字——number和JavaScript一样TypeScript里的所有数字都是浮点数。 这些浮点数的类型是 number。 除了支持十进制和十六进制字面量TypeScript还支持ECMAScript 2015中引入的二进制和八进制字面量。// number类型数据声明 let aNumber: number 123; console.log(aNumber); // 123 // 不同进制的数字 let decLiteral: number 6; let hexLiteral: number 0xf00d; let binaryLiteral: number 0b1010; let octalLiteral: number 0o744; // 数据类型转换 let aBoolean1: boolean Boolean(aNumber); let aBoolean2: boolean Boolean(0); console.log(aBoolean1); // true console.log(aBoolean2); // false let aString: string String(aNumber); console.log(aString); // 123 // 类型判断 console.log(typeof(aNumber)); // number字符串——stringJavaScript程序的另一项基本操作是处理网页或服务器端的文本数据。 像其它语言里一样我们使用 string表示文本数据类型。 和JavaScript一样可以使用双引号 或单引号表示字符串。// string变量声明 let nameString: string bob; nameString smith; console.log(nameString);你还可以使用模版字符串它可以定义多行文本和内嵌表达式。 这种字符串是被反引号包围 并且以${ expr }这种形式嵌入表达式// ES6 模板字符串 let nameS: string Gene; let age: number 37; let sentence: string Hello, my name is ${ nameS }. Ill be ${ age 1 } years old next month.; console.log(sentence); // 类型转换 let stringToBoolean: boolean Boolean(bob); console.log(stringToBoolean); // true // *(/) Number parseInt(parseFloat) new Number let stringToNumber: number Number(123); console.log(stringToNumber); // 123 // 类型判断 console.log(typeof(nameString)); // string数组——ArrayTypeScript像JavaScript一样可以操作数组元素。 有两种方式可以定义数组。 第一种可以在元素类型后面接上[]表示由此类型元素组成的一个数组let list: number[] [1, 2, 3];第二种方式是使用数组泛型Array元素类型let list: Arraynumber [1, 2, 3];元组——Tuple元组类型允许表示一个已知元素数量和类型的数组各元素的类型不必相同。 比如你可以定义一对值分别为string和number类型的元组。// Declare a tuple type let x: [string, number]; // Initialize it x [hello, 10]; // OK console.log(x[0].substr(1));枚举——enumenum类型是对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;对应js的代码// 枚举类 (enum) var Color; (function (Color) { Color[Color[Red] 0] Red; Color[Color[Green] 1] Green; Color[Color[Blue] 2] Blue; })(Color || (Color {}));Any有时候我们会想要为那些在编程阶段还不清楚类型的变量指定一个类型。 这些值可能来自于动态的内容比如来自用户输入或第三方代码库。 这种情况下我们不希望类型检查器对这些值进行检查而是直接让它们通过编译阶段的检查。 那么我们可以使用any类型来标记这些变量let notSure: any 4; notSure maybe a string instead; notSure false;void某种程度上来说void类型像是与any类型相反它表示没有任何类型。 当一个函数没有返回值时你通常会见到其返回值类型是voidfunction warnUser(): void { console.log(This is my warning message); }Null和UndefinedTypeScript里undefined和null两者各自有自己的类型分别叫做undefined和null。 和void相似它们的本身的类型用处不是很大// Not much else we can assign to these variables! let u: undefined undefined; let n: null null;默认情况下null和undefined是所有类型的子类型。 就是说你可以把null和undefined赋值给number类型的变量。然而当你指定了–strictNullChecks标记null和undefined只能赋值给void和它们各自。 这能避免很多常见的问题。 也许在某处你想传入一个string或null或undefined你可以使用联合类型string | null | undefined。nevernever类型表示的是那些永不存在的值的类型。 例如never类型是那些总是会抛出异常或根本就不会有返回值的函数表达式或箭头函数表达式的返回值类型 变量也可能是never类型当它们被永不为真的类型保护所约束时。Objectobject表示非原始类型也就是除numberstringbooleansymbolnull或undefined之外的类型。
typescript - 基础类型
typescript的数据类型分为如下布尔值——boolean数字——number字符串——string数组——Array元组——Tuple枚举——enumAnyvoidNull和UndefinedneverObject布尔值——boolean布尔值是最简单的数据类型有两个值true/false在JavaScript和TypeScript的里面一样// boolean变量的声明 let isDone: boolean true; console.log(isDone); // true // 类型转换 let numberBoolean1:number Number(isDone); let numberBoolean2:number Number(!isDone); // boolean装换成数字 true 1; false 0; console.log(numberBoolean1); // 1 console.log(numberBoolean2); // 0 let stringBoolean: string String(isDone); console.log(stringBoolean); // true // 类型判断 console.log(typeof(isDone)); // boolean数字——number和JavaScript一样TypeScript里的所有数字都是浮点数。 这些浮点数的类型是 number。 除了支持十进制和十六进制字面量TypeScript还支持ECMAScript 2015中引入的二进制和八进制字面量。// number类型数据声明 let aNumber: number 123; console.log(aNumber); // 123 // 不同进制的数字 let decLiteral: number 6; let hexLiteral: number 0xf00d; let binaryLiteral: number 0b1010; let octalLiteral: number 0o744; // 数据类型转换 let aBoolean1: boolean Boolean(aNumber); let aBoolean2: boolean Boolean(0); console.log(aBoolean1); // true console.log(aBoolean2); // false let aString: string String(aNumber); console.log(aString); // 123 // 类型判断 console.log(typeof(aNumber)); // number字符串——stringJavaScript程序的另一项基本操作是处理网页或服务器端的文本数据。 像其它语言里一样我们使用 string表示文本数据类型。 和JavaScript一样可以使用双引号 或单引号表示字符串。// string变量声明 let nameString: string bob; nameString smith; console.log(nameString);你还可以使用模版字符串它可以定义多行文本和内嵌表达式。 这种字符串是被反引号包围 并且以${ expr }这种形式嵌入表达式// ES6 模板字符串 let nameS: string Gene; let age: number 37; let sentence: string Hello, my name is ${ nameS }. Ill be ${ age 1 } years old next month.; console.log(sentence); // 类型转换 let stringToBoolean: boolean Boolean(bob); console.log(stringToBoolean); // true // *(/) Number parseInt(parseFloat) new Number let stringToNumber: number Number(123); console.log(stringToNumber); // 123 // 类型判断 console.log(typeof(nameString)); // string数组——ArrayTypeScript像JavaScript一样可以操作数组元素。 有两种方式可以定义数组。 第一种可以在元素类型后面接上[]表示由此类型元素组成的一个数组let list: number[] [1, 2, 3];第二种方式是使用数组泛型Array元素类型let list: Arraynumber [1, 2, 3];元组——Tuple元组类型允许表示一个已知元素数量和类型的数组各元素的类型不必相同。 比如你可以定义一对值分别为string和number类型的元组。// Declare a tuple type let x: [string, number]; // Initialize it x [hello, 10]; // OK console.log(x[0].substr(1));枚举——enumenum类型是对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;对应js的代码// 枚举类 (enum) var Color; (function (Color) { Color[Color[Red] 0] Red; Color[Color[Green] 1] Green; Color[Color[Blue] 2] Blue; })(Color || (Color {}));Any有时候我们会想要为那些在编程阶段还不清楚类型的变量指定一个类型。 这些值可能来自于动态的内容比如来自用户输入或第三方代码库。 这种情况下我们不希望类型检查器对这些值进行检查而是直接让它们通过编译阶段的检查。 那么我们可以使用any类型来标记这些变量let notSure: any 4; notSure maybe a string instead; notSure false;void某种程度上来说void类型像是与any类型相反它表示没有任何类型。 当一个函数没有返回值时你通常会见到其返回值类型是voidfunction warnUser(): void { console.log(This is my warning message); }Null和UndefinedTypeScript里undefined和null两者各自有自己的类型分别叫做undefined和null。 和void相似它们的本身的类型用处不是很大// Not much else we can assign to these variables! let u: undefined undefined; let n: null null;默认情况下null和undefined是所有类型的子类型。 就是说你可以把null和undefined赋值给number类型的变量。然而当你指定了–strictNullChecks标记null和undefined只能赋值给void和它们各自。 这能避免很多常见的问题。 也许在某处你想传入一个string或null或undefined你可以使用联合类型string | null | undefined。nevernever类型表示的是那些永不存在的值的类型。 例如never类型是那些总是会抛出异常或根本就不会有返回值的函数表达式或箭头函数表达式的返回值类型 变量也可能是never类型当它们被永不为真的类型保护所约束时。Objectobject表示非原始类型也就是除numberstringbooleansymbolnull或undefined之外的类型。