TypeScript学习笔记(二):基本数据类型及数据转换
数据类型
我们来看看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学习笔记(二):基本数据类型及数据转换的更多相关文章
- Typescript 学习笔记二:数据类型
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- Java学习笔记二:数据类型II
GitHub代码练习地址:https://github.com/Neo-ML/JavaPractice/blob/master/Intpractice3.java 一 Java中的数据类型 Java ...
- python学习笔记(二):python数据类型
上一篇博客写了python的入门和简单流程控制,这次写python的数据类型和各种数据类型的内置方法.一.数据类型是什么鬼?计算机顾名思义就是可以做数学计算的机器,因此,计算机程序理所当然地可以处理各 ...
- Typescript 学习笔记七:泛型
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- Typescript 学习笔记六:接口
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- Typescript 学习笔记五:类
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- Typescript 学习笔记四:回忆ES5 中的类
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- Typescript 学习笔记三:函数
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- Typescript 学习笔记一:介绍、安装、编译
前言 整理了一下 Typescript 的学习笔记,方便后期遗忘某个知识点的时候,快速回忆. 为了避免凌乱,用 gitbook 结合 marketdown 整理的. github地址是:ts-gitb ...
- Java IO学习笔记二
Java IO学习笔记二 流的概念 在程序中所有的数据都是以流的方式进行传输或保存的,程序需要数据的时候要使用输入流读取数据,而当程序需要将一些数据保存起来的时候,就要使用输出流完成. 程序中的输入输 ...
随机推荐
- RazorEngine 3.6.5.0
public class Person { public string Name { get; set; } public string Code { get; set; } } var templa ...
- bzoj1043
每次做计算几何题都要做好久 考虑每个圆对答案的贡献,也就是每个圆被后面圆覆盖还有多少 可以把覆盖当成盖住一段弧度,看最后有多少没被覆盖 这就相当于线段覆盖问题了, 推推公式,算极角然后排序即可 md, ...
- HDU 1078 FatMouse and Cheese【记忆化搜索】
题意:给出n*n的二维矩阵,和k,老鼠每次最多走k步,问老鼠从起点(0,0)出发,能够得到的最大的数(即为将每走过一点的数都加起来的和最大)是多少 和上一题滑雪一样,搜索的方向再加一个循环 #incl ...
- SVN备份及其还原 — dump/load方法
本文中采用最简单的dump/load方法.备份:一个较大的Subsersion版本库想用最少的空间来将它备份下来,用这个命令(请将/repo替换成你的版本库路径)svnadmin dump --del ...
- 监听某个div或其它标签的大小改变来执行相应的处理
jquery 默认的resize只能监听到浏览器窗口大小的改变,但我们在实际使用过程中有可能还需要监听某个div或其它标签的大小改变来执行相应的处理,如果使用默认的resize就无能为力了.怎么办呢, ...
- cocos2d-x 滚动文字(二)
http://blog.csdn.net/kuovane/article/details/8131789 首先送上demo,下载地址为:demo下载地址 一,怎么在文字前面空两隔?只需在xml里的文字 ...
- OK335xS mac address hacking
/*********************************************************************** * OK335xS mac address hacki ...
- 最简单的视音频播放示例9:SDL2播放PCM
本文记录SDL播放音频的技术.在这里使用的版本是SDL2.实际上SDL本身并不提供视音频播放的功能,它只是封装了视音频播放的底层API.在Windows平台下,SDL封装了Direct3D这类的API ...
- 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:/// ...
- 使用ffmpeg实现转码样例(代码实现)
分类: C/C++ 使用ffmpeg实现转码样例(代码实现) 使用ffmpeg转码主要工作如下: Demux -> Decoding -> Encoding -> Muxing 其中 ...