该文章用于督促自己学习TypeScript,作为学笔记进行保存,如果有错误的地方欢迎指正

2019-03-27  16:50:03


一、什么是TypeScript?

TypeScript是javascript的超集,在ts中可以使用所有的js代码,并对js进行了扩展,包括类型效验,数据类型,接口等

如图所示,TypeScript包含了javascript并进行延伸

二、准备工作

在说TypeScript之前先说一下如何让ts编译为js代码

首先安装 typescrpt,

npm install -g typescript 

将ts编译为js代码,在命令行中输入

tsc index.ts

但不能每次写完代码都输入一遍 tsc 来进行编译吧?那也太麻烦了,我们能不能直接保存就自动编译呢?可以的,下面是使用VScode的自动编译方法

首先在文件根目录下打开命令行输入,

tsc --init

输入以后会在文件中出现一个 tsconfig.json 文件

在文件中将 "outDir" : "./"打开,改为 "outDir" : "./js" ,表示编译后的 .js 文件 的存放位置

在 VScode 的工具栏中选择:终端 --> 运行任务

在工具栏弹出框里选择:

tsc:监视 - tsconfig.json

这样就配置完成了,可以在文件中试一试,保存ts文件后,会在文件中生成一个名为js的文件,里面就是编译后的 同名.js 文件,在html中引入js,就可以进行测试了

三、TypeScript的数据类型

1)布尔值类型(boolean)

使用 ts 的高级工具 类型注解来创建一个变量 bol ,要求 变量bol 的值得类型为 boolean 类型,否则会报错

2)数字类型(number)

支持所有浮点数,并支持二进制、八进制、十进制、十六进制的写法

3)字符串类型(string)

支持双引号 " "、单引号 ' ' 和模板字符串 ` `

4)数组类型(Array)

创建模板字符串有两种方式:

第一种:在变量名的类型后面加上 [ ] ,表示数组内的元素都是同一个类型:

第二种:是数组泛型,使用Array<元素类型>

5)元组类型(Tuple)

元组也是数组的一种,ts的数组如果使用使用类型注解来创建,数组的元素就具有效验的功能,但是未免太单一,而使用元组的方式创建数组,会稍微灵活那么一点点

使用元组来创建:

浏览器输出为:

在图示中可以看到,元组可以规定前两个元素的类型,下标为 0 的元素必须为 string,下标为 1 的元素必须为 number,而后的元素则会使用联合类型替代,可以是 string 或 number ,我尝试了隔空添加元素,下标为 2 的元素 显示为 empty(空),在遍历这个元组的时候,empty不会被遍历出来,只会遍历到 “10”  1  “123” ,对应的下标为0,1,3

图示中的报错是vscode插件的报错,不会影响运行

6)枚举类型(enum)

枚举类型可以是对状态码的标识,如 0 代表成功支付 ,1 代表失败支付,2 代表取消订单,3 代表未支付 这样的状态码标识不易读,可以使用枚举的方式来标识

看到枚举类型 Status 的输出,就明白了为什么可以得到 Status[1] 为success 了

枚举类型也可以不赋值,默认从 0 开始,一旦手动赋值后,前面的值不变,后面的值会依次递增

7)任意类型(any)

在实际使用中我们也许并不想让 ts 进行类型注解,就可以使用 any类型 ,any类型的好处在于,当我们不确定这个值为什么类型的时候,用 any类型注解 声明后的变量,他的类型是不确定的,从而使得这个变量可以调用任何不同类型的方法,但是编译器不会检查

可以使用 any 来进行数组的类型注解,不限制数组的元素类型

8)无类型(void)

void类型可以说与any类型完全相反,当函数没有返回值时返回的类型就是 void 类型,一般来说声明一个 void类型 的变量没有什么用,void 类型只能被赋值,undefined 和 null

在 typescript 中 默认情况下 undefined 和 null 是所有类型的子类型,可以将他们赋值给 number 类型的变量

当指定了严格模式 --strictNullChecks 后,undefined 和 null 只能赋值给他本身

9)never类型(never)

never类型表示永远不存在的值的类型,

引入官方文档的示例图

never类型是所有类型的子类型,但never类型本身没有子类型或任何类型都不能赋值给他,连any都不行,never只能赋值给never

9)Object类型

object类型表示非原始类型,就是除了 boolean,number,string,array,undefined,null 之外的类型

参考官方给的图片

图片示例的意思我理解的是这样的:

创建一个create函数,参数 o 的类型注解表示,参数的类型为 object 或者 null ,函数create的返回值为 void类型

接着调用函数,发现参数为 {prop:0} 和 null 是可以的

参数为 数字 42,字符串 "string",布尔值 false,无类型 undefined,都不可以

补充:类型断言

类型断言使用在告诉编译器,你已完全确定这个值的类型,编译器将会跳过数据检查,不影响运行

类型断言有两种写法

第一种:使用尖括号

第二种:使用 as 语法

注意:在 TypeScript 中使用 JSX,只能用 as语法 的类型断言

学习TypeScript,笔记一:TypeScript的简介与数据类型的更多相关文章

  1. vue.js 学习笔记3——TypeScript

    目录 vue.js 学习笔记3--TypeScript 工具 基础类型 数组 元组 枚举 字面量 接口 类类型 类类型要素 函数 函数参数 this对象和类型 重载 迭代器 Symbol.iterat ...

  2. 学习TypeScript 笔记

    TypeScript 什么是TypeScript TypeScript 是 JavaScript 的一个超集,支持 ECMAScript 6 标准. TypeScript 由微软开发的自由和开源的编程 ...

  3. TypeScript笔记[5]泛型+Dictionary 转

    TypeScript笔记[5]泛型   在C++.C#.Java等主流编程语言中,一般对泛型编程提供了支持.合理利用泛型,可以提高开发效率.提升代码质量. 例如在C++编程语言中,常常利用下面的结构表 ...

  4. 【web开发学习笔记】Structs2 Result学习笔记(一)简介

    Structs2 Result学习笔记(一)简介 问题一 <struts> <constant name="struts.devMode" value=" ...

  5. Linux学习笔记之 Btrfs文件系统简介及使用

    Btrfs 也有一个重要的缺点,当 BTree 中某个节点出现错误时,文件系统将失去该节点之下的所有的文件信息.而 ext2/3 却避免了这种被称为”错误扩散”的问题. Btrfs相关介绍: Btrf ...

  6. TypeScript笔记 1--环境搭建

    TypeScript是什么 Typescript是JavaScript的超集,支持ES6特性并且提供了类型系统,可以编译成Javascript.是微软开发且已经在github上开源. ES6(ES20 ...

  7. WCF入门教程(四)通过Host代码方式来承载服务 一个WCF使用TCP协议进行通协的例子 jquery ajax调用WCF,采用System.ServiceModel.WebHttpBinding System.ServiceModel.WSHttpBinding协议 学习WCF笔记之二 无废话WCF入门教程一[什么是WCF]

    WCF入门教程(四)通过Host代码方式来承载服务 Posted on 2014-05-15 13:03 停留的风 阅读(7681) 评论(0) 编辑 收藏 WCF入门教程(四)通过Host代码方式来 ...

  8. 深度学习读书笔记之RBM(限制波尔兹曼机)

    深度学习读书笔记之RBM 声明: 1)看到其他博客如@zouxy09都有个声明,老衲也抄袭一下这个东西 2)该博文是整理自网上很大牛和机器学习专家所无私奉献的资料的.具体引用的资料请看参考文献.具体的 ...

  9. 每天成长一点---WEB前端学习入门笔记

    WEB前端学习入门笔记 从今天开始,本人就要学习WEB前端了. 经过老师的建议,说到他每天都会记录下来新的知识点,每天都是在围绕着这些问题来度过,很有必要每天抽出半个小时来写一个知识总结,及时对一天工 ...

  10. InfluxDB学习之InfluxDB的安装和简介

    最近用到了 InfluxDB,在此记录下学习过程,同时也希望能够帮助到其他学习的同学. 本文主要介绍InfluxDB的功能特点以及influxDB的安装过程.更多InfluxDB详细教程请看:Infl ...

随机推荐

  1. leetcode796

    public class Solution { public bool RotateString(string A, string B) { string temp = A; int len = A. ...

  2. 说说API的重放机制

    API的重放机制 我们在设计接口的时候,最怕一个接口被用户截取用于重放攻击.重放攻击是什么呢?就是把你的请求原封不动地再发送一次,两次...n次,一般正常的请求都会通过验证进入到正常逻辑中,如果这个正 ...

  3. ubuntu16配置mysql5.7主从同步

    测试环境如下: master: 10.0.0.26 slave01: 10.0.0.27 slave02: 10.0.0.28 一.三台机均安装mysql-server5.7 $ sudo apt-g ...

  4. windows上输入其他国家语言

    1.安装语言环境 2.先有语言环境再有该语言下的输入法toolkit工具集. 3.通过特定语言的属性可以查看键盘布局.

  5. Hadoop之HDFS(三)HDFS的JAVA API操作

    HDFS的JAVA API操作 HDFS 在生产应用中主要是客户端的开发,其核心步骤是从 HDFS 提供的 api中构造一个 HDFS 的访问客户端对象,然后通过该客户端对象操作(增删改查)HDFS ...

  6. solr java api 使用solrj操作zookeeper集群中的solrCloud中的数据

    1 导入相关的pom依赖 <dependencies> <dependency> <groupId>org.apache.solr</groupId> ...

  7. win7安装linux双系统

    整体流程大概就是下载启动盘制作工具以及linux镜像,这些步骤网上很多,我就不再重复了 这里以centos举例说几个我踩到的坑吧 1.选择开始安装后提示 Warning: /dev/root does ...

  8. Lambda02 函数式接口

    1 java8默认提供的函数式接口 1.1 Predicate /* * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rig ...

  9. Installing XGBoost on Mac OSX

      0. Get gcc with open mp.  Just paste and execute the following command in your terminal, once Home ...

  10. 3.python 发送邮件之smtplib模块

    SMTP(Simple Mail Transfer Protocol)是简单邮件传输协议,它是一组用于由源地址到目的地址的邮件传输规则. python中对SMTP进行了简单的封装,可以发送纯文本邮件, ...