TypeScript从入门到放弃

Posted jjgw

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了TypeScript从入门到放弃相关的知识,希望对你有一定的参考价值。

先点赞后关注,防止会迷路

寄语:长风破浪会有时,直挂云帆济沧海。 本文已收录至https://github.com/likekk/-Blog欢迎大家star ?????? ,共同学习,共同进步。如果文章有错误的地方,欢迎大家指出。后期将在将github上规划前端学习的路线和资源分享。

前言

亲爱的读者们,大家好,我是杨戬,一个在互联网前端苟且偷生的划水程序员,本编文章开始将带你入坑TypeScript。

个人认为TypeScript的前景还是可以的(可以接受反驳),怎么说呢?现在很多的框架已经从javascript向TypeScript拥抱了,谷歌也在大力支持TypScript的扩展,谷歌的Angular2.x+就是基于TypeScript,而且Vue3.0也在使用TypeScript进行重构(道听途说),我也不逼逼那么多了,我们直接开始吧!

技术图片

TypeScript介绍

介绍的话我就直接引用一些吧!毕竟有些东西肯定比我讲的好(拥有一颗谦卑的心),

  • TypeScript 是 JavaScript 的一个超集,支持 ECMAScript 6 标准,TypeScript扩展了JavaScript的语法。

  • TypeScript 由微软开发的自由和开源的编程语言。

  • TypeScript 设计目标是开发大型应用,它可以编译成纯 JavaScript,编译出来的 JavaScript 可以运行在任何浏览器上

  • 谷歌也在大力支持TypScript的扩展,谷歌的angular2.x+就是基于TypeScript

  • 最新的Vue、React也可以集成TypeScript

  • Node.js的框架nest.js、midway中用的就是TypeScript的语法

这里我多说一句:TypeScript入门十分简单,只要你有JavaScript语言的基础,那么学习TypeScript起来成本是相对较低的,可以不用像学习一门新的语言那样费劲。

TypeScript语言特性

TypeScript 是一种给 JavaScript 添加特性的语言扩展。在其上扩展的功能有许多,我们一起来看下都扩展了哪些功能。

  • 类型批注和编译时类型检查
  • 类型推断和类型擦除
  • 接口(interface)、枚举(enum)、Mixin
  • 泛型编程(很多编程语言都有)
  • 名字空间(namespace)
  • 元组(tuple)
  • Await

当然还有一些功能是从ES6移植过来的

  • 类(Class)
  • 模块(module)
  • lambda函数的箭头语法
  • 可选参数和默认参数

简单说几点JavaScript和TypeScript的区别

  • TypeScript是JavaScript的超集,扩展了JavaScript的语法,因此现有的JavaScript代码可与TypeScript一起工作无需任何修改,TypeScript通过类型注解提供编译时的静态类型检查。
  • TypeScript可处理已有的JavaScript代码,并只对其中的TypeScript代码进行编译

TypeScript的优点VSTypescript的缺点

TypeScript的优点

  • TypeScript增加了代码的可读性和可维护性
  • TypeScript非常包容
  • TypeScript拥用活跃的社区

TypeScript的缺点

  • 有一定的学习成本,需要理解接口(Interfaces)、泛型(Generics)、类(Classes)、枚举类型(Enums)等前端工程师可能不是很熟悉的概念
  • 短期可能会增加一些开发成本,毕竟要多写一些类型的定义,不过对于一个需要长期维护的项目,TypeScript 能够减少其维护成本
  • 集成到构建流程需要一些工作量
  • 可能和一些库结合的不是很完美

TypeScript安装,编译

首先需要安装TypeScript,必须有Node.js的环境,关于Node.js的安装环境推荐大家这一篇博文

Node.js安装配置教程,写得非常详细。

安装完成之后,我们使用命令行看下是否安装成功。

node -v 检查node版本

技术图片

node.js环境配置成功之后,我们全局安装一下TypeScript,这里有几种方法供大家使用,大家选择自己喜欢的方法就可以了。

  • 使用npm命令全局安装

npm install -g typescript

  • 使用cnpm命令安装

npm install cnpm --registry=https://registry.npm.taobao.org

cnpm install -g typescript

  • 使用yarn命令安装

npm install -g yarn 或者 cnpm install -g yarn

yarn global add typescript

安装完成之后,我们检查TypeScript是否安装成功

检查命令 tsc -v

如果出现版本信息,那么一般都是安装成功了,这里就不进行截图了

开发工具推荐使用 vscode进行开发,vscode也是微软旗下的产品,使用vscode开发TypeScript,只能用下面那张图来表达我内心的感受。

技术图片

当然也还有许多优秀的开发工具,但是我还是首选vscode。

技术图片

TypeScript的HelloWorld

所有的一切准备好之后,那就开始我们的开发之旅吧!

首先我们新建一个文件夹,创建好文件夹之后我们新建一个.ts为后缀名的文件,目录结构如下

技术图片

然后我们在index.ts文件内编写helloworld代码

let str:string="Hello World"
console.log(str)

TypeScript 转换为 JavaScript 过程如下图:

技术图片

刚开始看到这段代码的时候瞬间有JavaScript的影子,和JavaScript声明的变量的代码差不多,就是指定了类型。比较严谨。

由于浏览器是无法识别TypeScript的,所以我们需要将TypeScript进行编译成JavaScript语言,让浏览器可以识别。

tsc index.ts(直接在vscode的控制台执行)

编译之后的代码(index.js):

var str = "Hello World";
console.log(str);

此时编译成功之后该文件夹会自动生成index.js文件,而这个文件就是index.ts进行编译之后的文件。然后我们在新建index.html文件,引入编译之后的inde.js文件。文件目录如下。

技术图片

之后运行index.html文件就可以看到输出结果了。

TypeScript开发工具vscode自动编译.ts文件

我们想一个这样的问题,如果每次写一段代码都需要自己编译一下,试想一下工作量有多么大,那么有没有可能可以实现一边写代码一边让它自己进行编译呢?答案是肯定的。

1、使用vscode的控制台输入tsc --init命令

tsc --init

此时目录下会生成一个tsconfig.json文件

找到outDir这是配置项,然后修改自己想要.ts文件通过编译之后在指定地方生成.js文件的目录,我这里是同级目录下js这个文件夹生成.ts编译之后的文件。

修改之后tsconfig.json文件

技术图片

接下来看下整个文件的目录结构

技术图片
2、配置tsconfig.json文件
  • 找到vscode的Terminal选项

  • 找到Run task选项

  • 选择typescript选项

  • tsc:watch -tsconfig.json

完成这几个步骤之后你就可以疯狂编码了。

技术图片

结尾

如果觉得本篇文章对您有用的话,可以麻烦您给笔者点亮那个点赞按钮。 技术图片

对于杨戬这个暖男来说:真的非常有用,您的支持就是我前进的动力,我们下篇文章见。

【原创】|杨戬

原创不易,请勿白嫖。 二郎神杨戬,一个在互联网前端苟且偷生的划水程序员,专注于前端开发,善于技术分享。 如需转载,请联系作者或者保留原文链接,微信公众号搜索二郎神杨戬。

技术图片

以上是关于TypeScript从入门到放弃的主要内容,如果未能解决你的问题,请参考以下文章

GO语言从入门到放弃

Volatile从入门到放弃

python全栈开发从入门到放弃之函数基础

Handler机制从入门到放弃

vue-cli从入门到放弃

Python爬虫从入门到放弃(十九)之 Scrapy爬取所有知乎用户信息(下)