一、先讲讲 TypeScript

什么是 typeScript ?

typeScript 是 Javascript 的超集 我们用一张图来简单介绍下 ts 和 js 清清楚楚明明白白的关系~

为什么会出现 typeScript

在说 typeScript 之前 ,我们先了解下 Javascript。

JS里面一切皆为对象,通过原型链来定义了系列不同类型数据的原生方法,然后给到了系列可以改变上下文的奇淫巧技,让 JS 在使用起来的时候可以非常方便,不需要考虑过多,链上了咱们就疯狂使用,这样真的好么?( 灵魂拷问 )

而且在数据类型上,JS 也是没有过多的限制,只要你定了这个变量且赋值了,那么在该变量未被销毁之前,你也可以疯狂改变它的数据类型(基础数据类型)

在有了几年的开发经验之后,特别是参与过大型项目开发的同学就会发现,对于初学者来讲非常方便友好的特性,突然就变成了bug制造机。往往因为数据类型的判断,JS 都给出了一系列的方法,而且都还不是特别准确,这让一项严谨的开发者们变的有些不那么严谨,那么 typeScript 就出现了,让编程这项本来就需要非常严谨的工作,回归了本质。 这或许就是 typeScript 出现的原因。

如何使用 typeScript

如何使用的话题,其实对于有过几年的开发者来讲,最简单且最快速的学习方法就是打开 他们的官方文档,typeScript官方文档

但是了,我在阅读过程中查到了新的版本文档,阅读起来人性化了很多,这里也奉上地址 typeScript官方文档-V2

下面我们就先针对 typeScript 的基础知识来进行复习一下

二、 typeScript 的数据类型 (Basic Types)

typeScript 的 Basic Types 包含了哪些呢?

  • Boolean (布尔类型)
  • Number (数字类型)
  • String (字符串类型)
  • Array (数组类型)
  • Tuple (元组类型)
  • Enum (可枚举类型)
  • Any (任意类型)
  • Void (Void 类型)
  • Null & Undefined
  • Never (Never 类型)
  • Object (object 类型-非原始类型)
2.1.1 Boolean (布尔类型)

TypeScript 语法

let isBool: Boolean = false;

被编译成 ES5JavaScript

"use strict";
var isBool = false;
2.1.2 Number (数字类型)

TypeScript 语法

let nums: number = 123;

被编译成 ES5JavaScript

"use strict";
var nums = 123;
2.1.3 String (字符串类型)

TypeScript 语法

let str: string = "123";

被编译成 ES5JavaScript

"use strict";
var str = "123";
2.1.4 Array (数组类型)

TypeScript 语法

// 纯数组类型数组表示方式
let arr0: number[] = [123, 123];
// 使用数组泛型
let arr1: Array<number> = [123, 345];
let arr2: Array<string> = ["123", "345"];
let arr3: Array<any> = [123, "345", { title: "123" }];

被编译成 ES5JavaScript

"use strict";
// 纯数组类型数组表示方式
var arr0 = [123, 123];
// 使用数组泛型
var arr1 = [123, 345];
var arr2 = ["123", "345"];
var arr3 = [123, "345", { title: "123" }];
2.1.5 Tuple (元组类型)
稍微解释下什么叫元组类型,元组类型本质上也属于 数组类型的一种,是数组类型的子集,然后不同的一点在于,元组类型的数据长度是已知的。就是说我们为这里每一位数组中的数据定义类型。那这种类型就叫 ##元组类型##

TypeScript 语法

let tupleArr: [number, string];
tupleArr = [123, "123"];

被编译成 ES5JavaScript

"use strict";
var tupleArr;
tupleArr = [123, "123"];
2.1.6 Enum (可枚举类型)
稍微解释下什么叫可枚举类型,因为这对于大多数只了解 JS 的前端开发者来讲是一个新的数据类型,但是 `可枚举类型` 在 c/c#/java 中已经是非常常见的了。一句话概括就是,枚举是组织收集有关联变量的一种方式。来,我们先举个												

最新文章

  1. MySQL主从同步配置(Ubuntu)
  2. Redis 学习笔记
  3. RelativeLayout_布局
  4. WIN7下USB多点触摸,一次发多个数据包的延迟问题,重要!
  5. Innodb中的事务隔离级别和锁的关系(转)
  6. HDU 1079 Calendar Game(简单博弈)
  7. 4.2 CUDA Reduction 一步一步优化
  8. CSRF——攻击与防御
  9. File类的基本操作之InputStream字节输入流
  10. html label 标签的 for 属性
  11. JavaScript原生对象总纲
  12. 【开源】canvas图像裁剪、压缩、旋转
  13. 局域网下的html注入及DNS劫持
  14. ssh 隧道
  15. Sql Server 向上取整、向下取整、四舍五入取整
  16. NO.9: 令operator=返回一个reference to *this
  17. 从零开始写一个npm包及上传
  18. 11.1JS笔记
  19. ElasticStack系列之十七 &amp; 大文本搜索性能提升方案
  20. python之函数用法locals()

热门文章

  1. maven项目部署到tomcat中没有classe文件的问题汇总
  2. 学习python-20191203-Python Flask高级编程开发鱼书_第02章 Flask的基本原理与核心知识
  3. [LC] 79. Word Search
  4. u盘出现大文件无法复制的解决
  5. 2018湖南省赛B题“2018”
  6. 吴裕雄--天生自然HTML学习笔记:启动TOMCAT服务器时出现乱码解决方法
  7. Tuning xgboost in R:Part 1
  8. 《JavaScript算法》二分查找的思路与代码实现
  9. python 自动发送邮件遇到的问题
  10. 最新中文版虚拟机VMware Workstation隆重上市