TypeScript 入门教程学习笔记

1. 数据类型定义

类型 实例 说明
Number let num: number = 1; 基本类型
String let myName: string = 'Tom';
Boolean let isDone: boolean = false;
Array let arr: number[] = [1, 1, 2, 3, 5]; 用 any 表示数组中允许出现任意类型
Function 1. 函数声明


function sum(x: number, y: number): number {


  return x + y;


}


2. 函数表达式


let mySum: (x: number, y: number) => number = function (x: number, y: number): number {


  return x + y;


};
重载:返回值有多个类型时,可以使用重载定义多个函数类型,如:


function reverse(x: number): number;


function reverse(x: string): string;


function reverse(x: number | string): number | string {


 if (typeof x === 'number') {


  return Number(x.toString().split('').reverse().join(''));


 } else if (typeof x === 'string') {


  return x.split('').reverse().join('');


 }


}


TypeScript 会优先从最前面的函数定义开始匹配
Object 接口 参见下面详细内容
联合类型 let idNumber: string | number; 1. 联合类型的变量在被赋值的时候,会根据类型推论的规则推断出一个类型


2. 当不确定一个联合类型的变量到底是哪个类型的时候,我们只能访问此联合类型的所有类型中共有的属性或方法
内置对象 1. ECMAScript 的内置对象:Boolean、Error、Date、RegExp 等。


2. DOM 和 BOM 的内置对象:Document、HTMLElement、Event、NodeList 等。

let d: Date = new Date();


let r: RegExp = /[a-z]/;


function run() {


 let args: IArguments = arguments;


}
备注 1. undefined 和 null 是所有类型的子类型。


2. 忽略类型,使用any。

类型推论:TypeScript 会在没有明确的指定类型的时候推测出一个类型

2. 对象的类型——接口

接口使用 interface 来定义,

用于对类的一部分行为进行抽象,也常用于对「对象的形状(Shape)」进行描述。

2.1 定义简单对象

interface Person {
readonly id: number; // 只读属性
name: string;
age?: number; // 可选属性
[propName: string]: any; // 任意属性,any这个地方影响其他所有属性类型判断
} let tom: Person = {
id: 89757,
name: 'Tom',
age: 25,
gender: 'male'
};

2.2 定义数组

interface NumberArray {
[index: number]: number;
}
let fibonacci: NumberArray = [1, 1, 2, 3, 5];

一般不会这么做,因为这种方式很复杂,丢弃了数组的方法。

2.3 定义函数

interface SearchFunc {
(source: string, subString: string): boolean;
} let mySearch: SearchFunc;
mySearch = function(source: string, subString: string) {
return source.search(subString) !== -1;
}

3. 断言

语法

断言有两种语法:值 as 类型<类型>值,常用第一种。

为什么需要断言

1. 将一个联合类型断言为其中一个类型

当 TypeScript 不确定一个联合类型的变量到底是哪个类型的时候,我们只能访问此联合类型的所有类型中共有的属性或方法,而有时候,我们确实需要在还不确定类型的时候就访问其中一个类型特有的属性或方法

2. 将一个父类断言为更加具体的子类

当类之间有继承关系时,类型断言也是很常见的

3. 将任何一个类型断言为 any

一方面不能滥用 as any,另一方面也不要完全否定它的作用,我们需要在类型的严格性和开发的便利性之间掌握平衡

4. 将 any 断言为一个具体的类型

遇到 any 类型的变量时,最好能够将调用了它之后的返回值断言成一个精确的类型,这样就方便了后续的操作

  • 要使得 A 能够被断言为 B,只需要 A 兼容 B 或 B 兼容 A 即可
  • 除非迫不得已,千万别用双重断言
  • 类型声明是比类型断言更加严格的,所以为了增加代码的质量,我们最好优先使用类型声明,这也比类型断言的 as 语法更加优雅。

3. 声明文件

由于ts不能识别通过 <script> 标签引入的第三方库对象,需要定义引入的第三方全局变量类型,

声明语句为:

declare var jQuery: (selector: string) => any;

通常把声明语句放到一个单独的文件(jQuery.d.ts)中,以 .d.ts 为后缀。

推荐使用 @types 统一管理第三方库的声明文件

npm install @types/jquery --save-dev

书写声明文件

  1. 创建一个 types 目录,专门用来管理自己写的声明文件
  2. 配置下 tsconfig.json 中的 paths 和 baseUrl 字段

tsconfig.json 内容:

{
"compilerOptions": {
"module": "commonjs",
"baseUrl": "./",
"paths": {
"*": ["types/*"]
}
}
}

4. 类型别名和字符串字面量类型

类型别名和字符串字面量类型都使用 type 定义

类型别名

类型别名可以给类型起一个名字,类型可以是一个也可以是多个

type Name = string | number;

let idNumber: Name = '001';

idNumber = 100;

字符串字面量类型

字符串字面量类型用来约束取值只能是某几个字符串中的一个

type EventNames = 'click' | 'scroll' | 'mousemove';

5. 元组

let tom: [string, number] = ['Tom', 25];

6. 枚举

枚举(Enum)类型用于取值被限定在一定范围内的场景

enum Days {Sun, Mon, Tue, Wed, Thu, Fri, Sat};

编译后得到的js文件

var Days;
(function (Days) {
Days[Days["Sun"] = 0] = "Sun";
Days[Days["Mon"] = 1] = "Mon";
Days[Days["Tue"] = 2] = "Tue";
Days[Days["Wed"] = 3] = "Wed";
Days[Days["Thu"] = 4] = "Thu";
Days[Days["Fri"] = 5] = "Fri";
Days[Days["Sat"] = 6] = "Sat";
})(Days || (Days = {}));

打印 Days 来看一看结构

{
"0": "Sun",
"1": "Mon",
"2": "Tue",
"3": "Wed",
"4": "Thu",
"5": "Fri",
"6": "Sat",
"Sun": 0,
"Mon": 1,
"Tue": 2,
"Wed": 3,
"Thu": 4,
"Fri": 5,
"Sat": 6
}

枚举项有两种类型:常数项计算所得项,计算所得项后的项无法自动获取初始值。

用到枚举的场景

枚举用来让代码更加语义化,比如有一条数据,0 代表停用, 1 代表启用

{ status: 0 }

你并不能很好的确定status为0是什么状态,使用enums能更清楚的知道是什么状态

enum Status = {disabled: 0, enabled: 1};

const data = {status: Status.disabled};

参考自:TypeScript 入门教程

TypeScript 入门教程学习笔记的更多相关文章

  1. Webpack新手入门教程(学习笔记)

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; text-align: center; font: 30.0px Helvetica; color: #000000 } ...

  2. Git 极简入门教程学习笔记

    Git 极简入门教程  http://rogerdudler.github.io/git-guide/index.zh.html 测试用 https://github.com/xxx/BrnShop. ...

  3. 《TypeScript入门教程》笔记

    基础 原始数据类型 布尔值 let isDone: boolean = false; 数值 let decLiteral: number = 6; 字符串 let myName: string = ' ...

  4. jfinal框架教程-学习笔记

    jfinal框架教程-学习笔记 JFinal  是基于 Java  语言的极速  WEB  + ORM  开发框架,其核心设计目标是开发迅速.代码量少.学习简单.功能强大.轻量级.易扩展.Restfu ...

  5. .NetCore微服务Surging新手傻瓜式 入门教程 学习日志---先让程序跑起来(一)

    原文:.NetCore微服务Surging新手傻瓜式 入门教程 学习日志---先让程序跑起来(一) 写下此文章只为了记录Surging微服务学习过程,并且分享给广大想学习surging的基友,方便广大 ...

  6. .NetCore微服务Surging新手傻瓜式 入门教程 学习日志---结构简介(二)

    原文:.NetCore微服务Surging新手傻瓜式 入门教程 学习日志---结构简介(二) 先上项目解决方案图: 以上可以看出项目结构可以划分为4大块,1是surging的核心底层,2,3,4都可以 ...

  7. 尚硅谷韩顺平Linux教程学习笔记

    目录 尚硅谷韩顺平Linux教程学习笔记 写在前面 虚拟机 Linux目录结构 远程登录Linux系统 vi和vim编辑器 关机.重启和用户登录注销 用户管理 实用指令 组管理和权限管理 定时任务调度 ...

  8. 【笔记目录2】【jessetalk 】ASP.NET Core快速入门_学习笔记汇总

    当前标签: ASP.NET Core快速入门 共2页: 上一页 1 2  任务27:Middleware管道介绍 GASA 2019-02-12 20:07 阅读:15 评论:0 任务26:dotne ...

  9. JProfiler使用详细教程学习笔记

    JProfiler学习笔记    推荐文章:JProfiler 入门教程 一.安装JProfiler        从http://www.ej-technologies.com/下载5.1.2并申请 ...

随机推荐

  1. linux awk基本语法命令总结

    一.基本用法 文本内容准备 2 this is a test 3 Are you like awk This's a test 10 There are orange,apple,mongo 用法一: ...

  2. filleSystemBasises

    基本查询命令 pwd 查看当前目录 dir 显示当前目录下的文件信息 more 查看文本文件的具体内容 cd 修改用户当前目录 mkdir 创建新的目录 rmdir 删除目录 copy filenam ...

  3. VMware 16.1虚拟机安装

    VMware 16.1创建虚拟机 1.1首先打开我们安装好的VMware点击创建新的虚拟机 典型为自动安装,接口位默认 自定义安装更自由,可以把按需求选择 VMware16版本,只能选择Worksta ...

  4. 安装蓝鲸paas社区版

    安装蓝鲸paas社区版http://docs.bk.tencent.com/bkce_install_guide/setup/get_ready.html#hostssystemctl stop fi ...

  5. C++ 中的 inline 详解

    inline:是一个关键词,放在一个函数前面,说明这个函数是inline函数. inline函数是什么?inline有什么作用? 为了解答这个问题,我们首先要知道编译器是如何为我们工作的. 先看一段代 ...

  6. Openstack Ocata 负载均衡安装(二)

    Openstack OCATA 负载节点(二) 安装haproxy: apt install haproxy 配置haproxy: vim /etc/haproxy/haproxy.cfg globa ...

  7. 【Docker】Docker概述、理解docker的集装箱、标准化、隔离的思想、 docker出现解决了什么问题

    整理一下 慕课网 第一个docker化的java应用 Docker环境下的前后端分离项目部署与运维 课程时所做的笔记 Docker概述 docker - https://www.docker.com/ ...

  8. 分布式系统:xxl-job改造spring-cloud

    目录 改造原因 主要改造思路 调度中心 调度中心 执行器侧 总结 修改后的源码仓库地址:GitHub. : 改造原因 原有的xxl-job使用自己实现的http协议进行注册以及调度等,与目前框架中本身 ...

  9. 浅入深出了解XXE漏洞

    环境搭建 https://github.com/c0ny1/xxe-lab 为了更深入的理解,我准备理论和实际相结合的了解XXE! 浅谈XML 初识XML 一个好的代码基础能帮助你更好理解一类漏洞,所 ...

  10. 一种获取context中keys和values的高效方法 | golang

    我们知道,在 golang 中的 context 是一个非常重要的包,保存了代码活动的上下文.我们经常使用 WithValue() 这个方法,来往 context 中 传递一些 key value 数 ...