转载:https://github.com/MyErpSoft/TypeScript-Handbook/blob/master/pages/zh-CHS/Basic%20Types.md

概述

为了让程序更易用,我们兼容几种最基本的数据类型:numbers(数字),strings(字符串),structures(结构),boolean(布尔值)等等。在 TypeScript 中,我们支持和 Javascript 几乎一样多的类型,并且新增了实用的枚举类型。

Boolean 布尔值

最基础的数据类型就是简单的 true(真)/false(假) ,在 Javascript 和 TypeScript (以及其他语言)中被称作是 "boolean(布尔值)"。

  1. var isDone: boolean = false;

Number 数字

和 Javascript 一样,在 TypeScript 中所有的number都是浮点值。 TypeScript 除了支持ECMAScript 2015中的十六进制和十进制外,还支持二进制和二进制类型。

  1. var decLiteral: number = 6;
  2. var hexLiteral: number = 0x9837abdef;
  3. var binaryLiteral: number = 0b0010;
  4. var octalLiteral: number = 0o74563;

String 字符串

在使用JavaScript创建网页或应用程序时,要用到很基础的功能是处理字符串,和其他语言一样,我们使用 "string" 类型来表示那些文本数据。和 JavaScript 一样,TypeScript 也使用双引号或单引号来围绕字符串数据。

  1. var name: string = "bob";
  2. name = 'smith';

你也可以使用 模板字符串,他能支持多行文本和内嵌表达式。这些字符串使用单引号(`)包围,并且嵌入的表达式使用${ expr }这样的形式表示。

  1. var name: string = `Gene`;
  2. var age: number = 37;
  3. var sentence: string = `Hello, my name is ${ name }.
  4.  
  5. I'll be ${ age + 1 } years old next month.`

上面的表达式相当于下面的声明方式:

  1. var sentence: string = "Hello, my name is " + name + ".\n\n" +
  2. "I'll be " + (age + 1) + " years old next month."

Array 数组

TypeScript 和 Javascript 一样,允许你使用数组。数组类型的定义可以有两种写法。第一种写法,你在数组元素类型后面添加‘[]’来表示这是一个该类型的数组:

  1. var list: number[] = [1, 2, 3];

第二种写法使用一种通用的数组类型表示,Array<数组元素类型>:

  1. var list: Array<number> = [1, 2, 3];

Tuple 元组

元组类型允许表达固定数量的已知类型集合,但这些类型不必是相同的。例如,您可能想表示一个'stringnumber`组合的类型:

  1. // 声明一个元组类型
  2. var x: [string, number];
  3. // 初始化他
  4. x = ['hello', 10]; // 准确
  5. // 错误的初始化
  6. x = [10, 'hello']; // 错误

我们可以使用数字检索一个已知的元素,但需要注意类型正确。

  1. console.log(x[0].substr(1)); // 正确
  2. console.log(x[1].substr(1)); // 错误,'number' 类型没有 'substr' 方法

当访问的索引超过边界时,将使用联合类型处理:

  1. x[3] = 'world'; // 正确,string允许被分配到 (string | number)
  2. console.log(x[5].toString()); // 正确,'string' 和 'number' 都有 toString 方法
  3. x[6] = true; // 错误,布尔值不是 (string | number) 中的一种

联合类型是更高级的议题,我们会在后续的章节中介绍。

Enum 枚举

TypeScript拓展了JavaScript原生的标准数据类型集,增加了枚举类型(enum)。枚举是一种很有用的数据类型,就像C#等语言中一样,它提供了一种给数字类型的值,设置易于辨别的名字的方法。

  1. enum Color {Red, Green, Blue};
  2. var c: Color = Color.Green;

在默认情况下,枚举类型会从数字0开始标记它的元素。我们可以通过人为地设置元素的数值来改变默认值。例如,上面的例子我们可以设置成从1开始计数:

  1. enum Color {Red = 1, Green, Blue};
  2. var c: Color = Color.Green;

我们甚至可以给所有的枚举元素设置数值:

  1. enum Color {Red = 1, Green = 2, Blue = 4};
  2. var c: Color = Color.Green;

枚举类型有一个便捷特性,我们也可以直接用数值来查找其对应的枚举元素的名称。举例来说,如果我们有一个值为2,但我们不确定这个数值对应枚举类型中的哪个元素,那我们可以直接查找这个数值对应的名称:

  1. enum Color {Red = 1, Green, Blue};
  2. var colorName: string = Color[2];
  3.  
  4. alert(colorName);

Any

当我们编写应用时,我们可能会需要描述一些类型不明确的变量。因为这些变量的值可能来源于一些动态的内容,如用户或第三方提供的库。在这种情况下,我们需要略过对这些变量进行的类型检查,让它们直接通过编译时的检查。为了实现这一目的,我们可以把它们标识为'any'类型:

  1. var notSure: any = 4;
  2. notSure = "maybe a string instead";
  3. notSure = false; // okay, definitely a boolean

使用'any'类型是处理我们已有的JavaScript代码的一种强大的方式,我们可以用它来逐渐增加或减少在编译过程中的类型检查。 就像其他编程语言那样,你可能期望使用Object来实现这个功能,但是注意在JavaScript中,Object类型仅仅允许分配任意值给他,但不能调用他的存在或可能的任何方法:

  1. var notSure: any = 4;
  2. notSure.ifItExists(); // 没问题,在运行时有可能有 ifItExists 这个方法
  3. notSure.toFixed(); // 没问题,toFixed 是真实存在的方法 (但是编译器不会验证准确性)
  4. var prettySure: Object = 4;
  5. prettySure.toFixed(); // 错误,不行就是不行了,使用any吧

当我们知道一个类型的部分数据类型,却又不确定所有的数据类型时,使用'any'可以为我们提供不少方便。比如你有一个数组,但是这个数组中的元素属于不同的数据类型,那你可以这么做:

  1. var list: any[] = [1, true, "free"];
  2.  
  3. list[1] = 100;

Void

void就像any的相反面:void就是没有,any就是所有。没有返回值的函数就可以认为是'void'类型:

  1. function warnUser(): void {
  2. alert("This is my warning message");
  3. }

不建议声明一个变量是 void类型,因为这个变量就只能赋值undefined 或 null

  1. var unusable: void = undefined;

感谢翻译

《TypeScript 中文入门教程》 1、基础数据类型的更多相关文章

  1. 转载:TypeScript 简介与《TypeScript 中文入门教程》

    简介 TypeScript是一种由微软开发的自由和开源的编程语言.它是JavaScript的一个超集,而且本质上向这个语言添加了可选的静态类型和基于类的面向对象编程.安德斯·海尔斯伯格,C#的首席架构 ...

  2. 转载:《TypeScript 中文入门教程》

    缘由 事情是这样的,我想搜索 TypeScript 中文教程,结果在 https://www.baidu.com , https://cn.bing.com ,上都找不到官方的翻译,也没有一个像样的翻 ...

  3. 【转】TypeScript中文入门教程

    目录 虽然我是转载的,但看在Copy这么多文章也是很幸苦的好吧,我罗列一个目录. 转载:<TypeScript 中文入门教程> 17.注解 (2015-12-03 11:36) 转载:&l ...

  4. 《TypeScript 中文入门教程》

    转载:<TypeScript 中文入门教程> 17.注解 (2015-12-03 11:36) 转载:<TypeScript 中文入门教程> 16.Symbols (2015- ...

  5. 转载:《TypeScript 中文入门教程》 12、类型推导

    版权 文章转载自:https://github.com/zhongsp 建议您直接跳转到上面的网址查看最新版本. 介绍 这节介绍TypeScript里的类型推论.即,类型是在哪里如何被推断的. 基础 ...

  6. 转载:《TypeScript 中文入门教程》 11、声明合并

    版权 文章转载自:https://github.com/zhongsp 建议您直接跳转到上面的网址查看最新版本. 介绍 TypeScript有一些独特的概念,有的是因为我们需要描述JavaScript ...

  7. 转载:《TypeScript 中文入门教程》 9、泛型

    版权 文章转载自:https://github.com/zhongsp 建议您直接跳转到上面的网址查看最新版本. 介绍 软件工程中,我们不仅要创建一致的定义良好的API,同时也要考虑可重用性. 组件不 ...

  8. 转载:《TypeScript 中文入门教程》 8、函数

    版权 文章转载自:https://github.com/zhongsp 建议您直接跳转到上面的网址查看最新版本. 介绍 函数是JavaScript应用程序的基础. 它帮助你实现抽象层,模拟类,信息隐藏 ...

  9. 转载:《TypeScript 中文入门教程》 17、注解

    版权 文章转载自:https://github.com/zhongsp 建议您直接跳转到上面的网址查看最新版本. 介绍 随着TypeScript和ES6里引入了类,现在在一些场景下我们会需要额外的特性 ...

随机推荐

  1. 搞懂 SynchronizationContext(第一部分)【翻译】

    SynchronizationContext -MSDN 很让人失望 我不知道为什么,目前在.Net下关于这个类只有很少的资料.MSDN文档也只有很少的关于如何使用SynchronizationCon ...

  2. 前端编码规范之JavaScript

    上次浅谈了下关于CSS的编码规范,大部分童鞋持赞同意见,仍存在一些童鞋不太理解这些规范的意义. 如果是个人或者小作坊开发,其实这些所谓的编码规范也没啥意思,因为大家写好的代码直接就给扔到网上去了,很少 ...

  3. js创建对象的高级模式

    hello,安瑞万.第一次写博客,心情很激动啊.要是说的不好,你来打我啊?反正你也不知道我家地址.好了,不扯了.进入正题:要是写的不好欢迎大家来批评指导. what:创建对象的三种模式 --1,门户大 ...

  4. <dependency>

      <dependency>             <groupId>org.hibernate</groupId>                       ...

  5. 人之初,性本动 - G2 2.1 发布

    前言 随着可视化进入深水区,G2面临了越来越多交互上的需求.动画是提升交互必不可少的一部分,也是之前G2的薄弱环节.这个版本里我们开发并替换了动画底层,统一了时间轴,使G2的动画性能大大提升,并提供了 ...

  6. 传智播客--高级控件--showdialog关闭(小白内容)

    以往我在WPF里,用ShowDialog展示出一个页面,一般都是用Close()进行关闭. 今天看传智播客的视频时,了解到还能直接给DialogResult一个TRUE或者false的属性,使页面关闭 ...

  7. C指针(一)

    原文链接:http://www.orlion.ga/916/ 一.指针的基本操作 例: int i; int *pi = &i; char c; char *pc = &c; &quo ...

  8. 深入理解闭包系列第三篇——IIFE

    × 目录 [1]实现 [2]用途 前面的话 严格来讲,IIFE并不是闭包,因为它并不满足函数成为闭包的三个条件.但一般地,人们认为IIFE就是闭包,毕竟闭包有多个定义.本文将详细介绍IIFE的实现和用 ...

  9. Restore Volume 操作 - 每天5分钟玩转 OpenStack(60)

    前面我们 backup 了 voluem,今天我们将讨论如何 restore volume. restore 的过程其实很简单,两步走: 在存储节点上创建一个空白 volume. 将 backup 的 ...

  10. Web APi之异常处理(Exception)以及日志记录(NLog)(十六)

    前言 上一篇文章我们介绍了关于日志记录用的是Log4net,确实也很挺强大,但是别忘了我们.NET有专属于我们的日志框架,那就是NLog,相对于Log4net而言,NLog可以说也是一个很好的记录日志 ...