从今天开始学习typescript了,记录ts学习点滴,最后,使用ts结合nodejs开发后端应用,一起共勉吧:

typescript最新版本2.6,所有演示代码均基于此版本

开始之前确定安装了如下npm包:

npm i typescript -g    // ts全局包
npm i ts-node -g // 使用ts-node可以直接运行ts文件

基础类型

布尔类型

let isDone: boolean = false
let isExist: boolean = true
console.log(isDone, isExist)

运行:

控制台执行命令:ts-node dataType.ts

->false true

数值类型(number)

ts的number类型继承了es6的number,额外支持二进制和八进制数值。

let decLiteral: number = 6;   // 十进制
let hexLiteral: number = 0xf00d; // 16进制
let binaryLiteral: number = 0b1010; // 二进制
let octalLiteral: number = 0o744; // 八进制
console.log(decLiteral, hexLiteral, binaryLiteral, octalLiteral)

运行:

6 61453 10 484

字符串类型

let str: string = '我是晁州,我很可爱。。。'
console.log(str);

运行:

我是晁州,我很可爱。。。

模板字符串:

let str: string = '我是晁州,我很可爱。。。'
console.log(str);
let tempString: string = `i am a template str:${str}`
console.log(tempString);

运行:

我是晁州,我很可爱。。。
i am a template str:我是晁州,我很可爱。。。

数组类型

let arr1: Array<number> = [1,2,3,4]   // 使用尖括号形式声明(数组泛型)
console.log(arr1);
let arr2: number[] = [2,3,4,5] // 使用方括号声明
console.log(arr2);

运行:

[ 1, 2, 3, 4 ]
[ 2, 3, 4, 5 ]

元组类型(Tuple)

元组类型和数组相似,不同的是,元组每一项的数据类型可以不同(数组使用any类型也可以实现每一项类型不同)

每一项的元素类型必须一致,否则编译出错
let tuple1: [string, number, boolean]
tuple1 = ['admin', 34, false]
console.log(tuple1);

运行:

[ 'admin', 34, false ]

枚举类型

ts支持枚举类型,使用如下:

enum Color {red, green, blue}   // 默认从0开始编号,即red=0,可以直接指定red=1开始
let c: Color = Color.red
console.log(c === 0, c === Color.red); let colorName: string = Color[1]
console.log('Color[1]的name是:', colorName);

运行:

true true
Color[1]的name是: green

any类型

any类型表示任意类型,类似于golang中的interface{}类型,any类型可以赋值任意类型。

let any1: any = 4
console.log(any1);
any1 = false
console.log(any1);
any1 = undefined
console.log(any1);
let anyArr: any[] = [1, true, 'hello']
console.log(anyArr);
let anyArr2: Array<any> = [false, 0x1234, 'world'] // 泛型声明
console.log(anyArr2);

运行:

4
false
undefined
[ 1, true, 'hello' ]
[ false, 4660, 'world' ]

void类型(空类型)

void类型表示没有任何类型,func无返回值时可以使用此类型。

function voidFunc(): void {
console.log('void function invoked!');
} voidFunc() let voidVar: void = undefined // void类型只能赋值undefined或null
console.log(voidVar);
voidVar = null
console.log(voidVar);

运行:

void function invoked!
undefined
null

undefined和null类型

这两种类型是所有类型的子类型,没毛线用。

let a: undefined = undefined
let b: null = null
console.log(a, b); let num1: number = 2
console.log(num1);
num1 = a // undefined或null类型可以被任意类型给赋值,和any恰好相反
console.log(num1);
let c: any
c = 23
console.log(c);

运行:

undefined null
2
undefined
23

never类型

never类型是那些总是会抛出异常,或者根本就不会有返回值的函数返回值类型。

let a: never
let b: string = 'admin'
b = a
console.log(a, b); function error(msg: string): never {
throw new Error(msg)
} function neverFunc(): never{
while(true){ }
}

运行:

undefined undefined

类型断言

断言好比其它语言里的类型转换,但是不进行特殊的数据检查和结构。

let someValue: any = 'i am a unknown value'
console.log(someValue.length);
let len: number = (someValue as string).length
console.log(len);

运行:

20
20

今晚就学习到这里了,ps:很多时候自己亲手敲一遍强于看文档十遍!下节继续吧!

我的博客即将同步至腾讯云+社区,邀请大家一同入驻。

TypeScript学习笔记之基础类型的更多相关文章

  1. TypeScript学习笔记之接口类型

    TypeScript的接口,个人理解就是一种约束,包括各种类型的契约或者代码定义上的契约.当然,和java中的用法基本一致,接口可以被继承也可以被实现. 定义一个简单的interface interf ...

  2. TS学习笔记----(一)基础类型

    布尔值: boolean let isDone: boolean = false; 数字: number 和JavaScript一样,TS里的所有数字都是浮点数. 支持十进制和十六进制字面量,TS还支 ...

  3. JDK7学习笔记之基础类型

    printf()的基础用法: 变量的基础用法: 字符的输出:

  4. C#学习笔记(基础知识回顾)之值类型与引用类型转换(装箱和拆箱)

    一:值类型和引用类型的含义参考前一篇文章 C#学习笔记(基础知识回顾)之值类型和引用类型 1.1,C#数据类型分为在栈上分配内存的值类型和在托管堆上分配内存的引用类型.如果int只不过是栈上的一个4字 ...

  5. C#学习笔记(基础知识回顾)之值类型和引用类型

    一:C#把数据类型分为值类型和引用类型 1.1:从概念上来看,其区别是值类型直接存储值,而引用类型存储对值的引用. 1.2:这两种类型在内存的不同地方,值类型存储在堆栈中,而引用类型存储在托管对上.存 ...

  6. MyBatis:学习笔记(1)——基础知识

    MyBatis:学习笔记(1)--基础知识 引入MyBatis JDBC编程的问题及解决设想 ☐ 数据库连接使用时创建,不使用时就释放,频繁开启和关闭,造成数据库资源浪费,影响数据库性能. ☐ 使用数 ...

  7. Typescript 学习笔记七:泛型

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

  8. Typescript 学习笔记六:接口

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

  9. Typescript 学习笔记五:类

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

随机推荐

  1. java多线程创建-Thread,Runnable,callable和threadpool

    java创建多线程的方式有许多种,这里简要做个梳理 1. 继承Thread类 继承java.lang.Thread类,创建本地多线程的类,重载run()方法,调用Thread的方法启动线程.示例代码如 ...

  2. java获取泛型信息

    总结一下java中获取与泛型相关的信息的知识,不如说是使用方法.网上也有很多类似的优秀文章,这里主要做一个知识的总结.通过反射获取泛型信息的常见例子: //bean package testProje ...

  3. C# 处理Word自动生成报告 一、概述

    经常遇到这样的需求, 生成Word格式的报告, 而不是单纯的一张表格的报表.  就像体检报告一样. 数据来源部分决定采用一个存储过程返回Dataset的方式, 整张报告的数据来源于此Dataset的多 ...

  4. 父类清除浮动的原因、(清除浮动代码,置于CSS中方便调用)

    浮动因素在静态网页制作中经常被应用到,比如要让块级元素不独占一行,常常应用设置float的方式来实现.但是应用的时候会发现,设置了子类浮动后,未给父类清除浮动,这样就会造成一下问题: 1.浮动的元素会 ...

  5. npoi导入导出

    NPOI是指构建在POI 3.x版本之上的一个程序,NPOI可以在没有安装Office的情况下对Word或Excel文档进行读写操作. NPOI是一个开源的Java读写Excel.WORD等微软OLE ...

  6. 学习MySQL(下)

    具体实例 22.MySQL ALTER命令 当我们需要修改数据表名或者修改数据表字段时,就需要使用到MySQL ALTER命令. 1.如果需要修改数据表的名称,可以在 ALTER TABLE 语句中使 ...

  7. 晓莲说-何不原创:java 实现二维数组冒泡排序

    新手从业路-为自己回顾知识的同时,也希望和大家分享经验: 话不多说,上代码 public class 冒泡排序 { /**     * @param admin     * @2017.12.4   ...

  8. [flask实践] 解决mysql数据库不支持中文的问题

    接上一篇文章,在解决了mysql+flask环境配置问题之后,往数据库存中文字符串会报1366错误,提示不正确的字符.继而发现默认的mysql采用了Latin1字符集,这种编码是不支持中文的. 如果想 ...

  9. DOM操作中,getElementByXXXX 和 querySelector 的区别

    1. 返回值:     getElements返回动态集合:       优: 首次查找效率高      缺: 可能造成反复查找DOM树    querySelector返回非动态集合:      优 ...

  10. UVA434 - Matty's Blocks

    题意:已知前视图和右视图,求最少需要几个正方体以及至多可以再增加几个正方体. 分析:先对于最小木块数,要想用最少的立方体搭建,那就意味着前视图中的每一竖立方体的高度最好都要被右视图中的高度所利用到.所 ...