数据类型

我们来看看TypeScript中的基本数据类型都有哪些。

boolean

布尔值,支持true和false。

var isDone: boolean = false;

默认为undefined,此时其和true与false判断都为false。

 var isDone: boolean;

 function run() {
alert(isDone == true);//false
alert(isDone == false);//false
} run();

所以在使用boolean类型时要记得赋初值,以便避免以后的麻烦。

number

数字类型,如下:

var height: number = 6;

首先,TypeScript中对于数字只有这么一种类型,没有byte、short、int、uint、long、float、double等类型,而TypeScript的number实际上是一个64为的双精度浮点数,可以看做其它语言中的double类型。

需要注意的是,当不进行初始赋值时,所有的基本数据类型都默认为undefined类型,下面不再重复讲解。

string

字符串类型,如下:

var name: string = "bob";
name = 'smith';

字符串的使用与JavaScript一致。

any

表示为任意类型,如下:

var notSure: any = 4;
notSure = "maybe a string instead";
notSure = false;

我们发现notSure可以设定为任意的类型。

我们也可以将其用在数组上,如下:

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

undefined和null

null和undefined基本是同义的,只有一些细微的差别。

undefined表示"缺少值",就是此处应该有一个值,但是还没有定义。

null表示"没有对象",即该处不应该有值。

参考:http://www.ruanyifeng.com/blog/2014/03/undefined-vs-null.html

void

用在函数返回值,和C++、Java用法一致,表示没有返回值:

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

Array

数组类型,可以有两种写法,如下:

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

二维数组

var num: string[][] = [["asdf", "zxc"],["adsf"]];

其它使用方法和JavaScript中一致。

Object

可以当做Hash表来使用,如下:

 var obj: Object = {};

 function run() {
obj["a"] = 123;
//obj.b = "asdf";//这种写法是错误的
obj["b"] = "asdf";
obj[100] = true; delete obj["100"];//删除使用 delete 关键字 for (var key in obj) {
alert(key);
alert(obj[key]);
}
} run();

需要注意的是,该类型的键都是字符串类型,即所有当做键的对象都会调用toString()方法获得对应的字符串来作为键值保存对象。

Enum

枚举类型,如下:

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

另一种格式:

enum Color {Red, Green, Blue};
var c: Color = Color[1];

同时还可以对每个枚举进行赋值,如下:

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

这样,Green自动被赋值为2,Blue自动被赋值为3。

也可以全部进行赋值:

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

我们还可以获得指定索引的枚举的名称:

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

需要注意的是,这里的值可以看做数组的下标,如下:

enum Color {Red = 100, Green, Blue};
var colorName: string = Color[101];
alert(colorName);//Green

数据转换

强制转换

将一个类型强制转换为另一个类型,如果转换失败编译时会报错,如下:

var str: string = <string> num;//转换成功
var strNum: number = <number> str;//编译报错

TypeScript中没有as关键字进行转换,都是强制转换。

instanceof

instanceof可以用来判断一个对象是否为指定的类型,如果是则返回true,否则返回false,如下:

if (obj instanceof String) {
alert("obj is string!");
}

typeof

可以获取类型的字符串描述:

 typeof 3 // "number"
typeof "abc" // "string"
typeof {} // "object"
typeof true // "boolean"
typeof undefined // "undefined"
typeof function(){} // "function"

可参考:http://tobyho.com/2011/01/28/checking-types-in-javascript/

TypeScript学习笔记(二):基本数据类型及数据转换的更多相关文章

  1. Typescript 学习笔记二:数据类型

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  2. Java学习笔记二:数据类型II

    GitHub代码练习地址:https://github.com/Neo-ML/JavaPractice/blob/master/Intpractice3.java 一  Java中的数据类型 Java ...

  3. python学习笔记(二):python数据类型

    上一篇博客写了python的入门和简单流程控制,这次写python的数据类型和各种数据类型的内置方法.一.数据类型是什么鬼?计算机顾名思义就是可以做数学计算的机器,因此,计算机程序理所当然地可以处理各 ...

  4. Typescript 学习笔记七:泛型

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  5. Typescript 学习笔记六:接口

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  6. Typescript 学习笔记五:类

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  7. Typescript 学习笔记四:回忆ES5 中的类

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  8. Typescript 学习笔记三:函数

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  9. Typescript 学习笔记一:介绍、安装、编译

    前言 整理了一下 Typescript 的学习笔记,方便后期遗忘某个知识点的时候,快速回忆. 为了避免凌乱,用 gitbook 结合 marketdown 整理的. github地址是:ts-gitb ...

  10. Java IO学习笔记二

    Java IO学习笔记二 流的概念 在程序中所有的数据都是以流的方式进行传输或保存的,程序需要数据的时候要使用输入流读取数据,而当程序需要将一些数据保存起来的时候,就要使用输出流完成. 程序中的输入输 ...

随机推荐

  1. RazorEngine 3.6.5.0

    public class Person { public string Name { get; set; } public string Code { get; set; } } var templa ...

  2. bzoj1043

    每次做计算几何题都要做好久 考虑每个圆对答案的贡献,也就是每个圆被后面圆覆盖还有多少 可以把覆盖当成盖住一段弧度,看最后有多少没被覆盖 这就相当于线段覆盖问题了, 推推公式,算极角然后排序即可 md, ...

  3. HDU 1078 FatMouse and Cheese【记忆化搜索】

    题意:给出n*n的二维矩阵,和k,老鼠每次最多走k步,问老鼠从起点(0,0)出发,能够得到的最大的数(即为将每走过一点的数都加起来的和最大)是多少 和上一题滑雪一样,搜索的方向再加一个循环 #incl ...

  4. SVN备份及其还原 — dump/load方法

    本文中采用最简单的dump/load方法.备份:一个较大的Subsersion版本库想用最少的空间来将它备份下来,用这个命令(请将/repo替换成你的版本库路径)svnadmin dump --del ...

  5. 监听某个div或其它标签的大小改变来执行相应的处理

    jquery 默认的resize只能监听到浏览器窗口大小的改变,但我们在实际使用过程中有可能还需要监听某个div或其它标签的大小改变来执行相应的处理,如果使用默认的resize就无能为力了.怎么办呢, ...

  6. cocos2d-x 滚动文字(二)

    http://blog.csdn.net/kuovane/article/details/8131789 首先送上demo,下载地址为:demo下载地址 一,怎么在文字前面空两隔?只需在xml里的文字 ...

  7. OK335xS mac address hacking

    /*********************************************************************** * OK335xS mac address hacki ...

  8. 最简单的视音频播放示例9:SDL2播放PCM

    本文记录SDL播放音频的技术.在这里使用的版本是SDL2.实际上SDL本身并不提供视音频播放的功能,它只是封装了视音频播放的底层API.在Windows平台下,SDL封装了Direct3D这类的API ...

  9. yum install错误 系统环境:Oracle Linux5.4 在通过yum安装软件时出现以下错误:

    1.yum配置文件 1 [root@rh168 yum.repos.d]# cat yum.repo  2 [base] 3 name=Oracle linux  4 baseurl=file:/// ...

  10. 使用ffmpeg实现转码样例(代码实现)

    分类: C/C++ 使用ffmpeg实现转码样例(代码实现) 使用ffmpeg转码主要工作如下: Demux -> Decoding -> Encoding -> Muxing 其中 ...