推荐在这里阅读

9012年都过半了,还不会用ts你就out了

why ?

  1. 三大框架angular2以后的版本完全是用ts开发的,
  2. vue对ts的支持也越来越好,
  3. React也有TSX组件

还在犹豫什么

本文不涉及框架内容,因为框架的cli已经帮你搭好了ts环境。。。

本文只教你如何在一个demo里搭建Ts环境,好了,我们开始吧

第一步,安装

全局安装typescript

npm install typescript -g

安装好以后,在你的项目里就可以使用tsc 命令了

tsc [ts文件名]

使用上面的命令就可以把某个ts文件编译成js文件

tsc

这是编译所有ts文件

第二步, 配置文件

恭喜你,走完第一步你已经成功一大半了!


新建一个json类型的配置文件, 文件名是tsconfig.json。

{
"compilerOptions": { // 编译选项
"target": "es2016", // 配置编译目标代码的版本标准
"module": "commonjs", // 配置编译目标使用的模块化标准
"lib": ["es2016"]
}
}

最简单的配置是这样,后面可以根据需求加上你需要的配置。


:::tip

注意!!!加入配置文件后,使用tsc 命令编译某个ts文件时不需要带上.ts文件后缀, 否则会忽略配置文件

:::

插播一条重要内容

我们的ts项目如果使用了第三方库,比如lodash,mock,jquery什么的,这些第三方库并不是用ts写的,


它们是用js写的,没有ts的类型检查, 怎么办?


有办法,官方有一个@types的类型库,它包含了很多对js代码的类型描述


比如你想用jquery, 你就可以安装@types/jquery。

ts和js分开

开发过程中我们肯定希望源代码和编译后的代码分开,加入以下两个配置选项


include : 需要编译的文件目录


outDir: 编译后的文件目录

{
"compilerOptions": { // 编译选项
"target": "es2016", // 配置编译目标代码的版本标准
"module": "commonjs", // 配置编译目标使用的模块化标准
"lib": ["es2016","dom"], // 配置环境
"outDir": "./dist"
},
"include": ["./src"]
}

第三步 简化开发流程

如果你只是想用ts写个hello world, 你已经可以做到了


假设你有个hello.ts文件,文件内容是console.log('hello world');

命令行依次执行:

tsc

node ./dist/hello.js

命令行就可以打印出 hello world


截至第二步, 每次修改文件你都要执行两步:

  1. 编译文件 tsc
  2. 执行文件 node ./dist/文件名


    我们可以使用第三方库来简化这个流程

ts-node

安装 npm install ts-node -D


命令行执行

ts-node /src/hello.ts

它可以在内存中直接编译ts并执行编译后的文件(不会生成dist目录)

这样还不够好,虽然它可以帮我们编译并执行,但是它不能检测代码的变化

nodemon

安装 npm install nodemon -D


命令行执行

nodemon --exec --watch src -e ts ts-node /src/hello.ts

--watch src表示只监控src文件夹下的文件


-e ts表示只监控ts文件的改变


这样你随便改hello.ts的内容它都会自动编译并运行。

最后把这条命令写在package.json的script里,完美收官!

结语

至此相信你对ts已经不那么陌生了,下篇和大家一起结合React和Ts开发个小demo,


帮你熟悉项目实战。

让你的项目使用Ts吧的更多相关文章

  1. vsCode怎么为一个前端项目配置ts的运行环境

    vsCode为一个前端项目配置ts的运行环境,ts文件保存的时候自动编译成js文件: 假设此前端项目名称为Web:文件结构如图 1. 在根目录中新建一个“.vscode”文件夹,里面建一个“tasks ...

  2. angular项目中ts的配置编译tsconfig.json

    { "compilerOptions": { /* 基本选项 */ "target": "es5", // 指定 ECMAScript 目标 ...

  3. angular4.0项目main.ts详解

    main.ts负责引导整个angular应用的起点 // 导入enableProdMode用来关闭angular开发者模式 import { enableProdMode } from '@angul ...

  4. 公共项目开发:我为什么用 JSDoc,而不用 ts

    公共模块,通常会被多个项目.不同的开发人员使用,所以开发公共模块时,你自己会用还不够,要让所有人都能很快的知道怎么去使用,这一点很关键.通常会从3个方面做到这点: 精心分割代码逻辑,遵循开闭原则: 变 ...

  5. vue项目中使用ts(typescript)入门教程

    最近项目需要将原vue项目结合ts的使用进行改造,这个后面应该是中大型项目的发展趋势,看到一篇不错的入门教程,结合它并进行了一点拓展记录之.本文从安装到vue组件编写进行了说明,适合入门. 1.引入T ...

  6. 视音频编解码学习工程:TS封装格式分析器

    =====================================================视音频编解码学习工程系列文章列表: 视音频编解码学习工程:H.264分析器 视音频编解码学习工 ...

  7. 原有vue项目接入typescript

    原有vue项目接入typescript 为什么要接入typescript javascript由于自身的弱类型,使用起来非常灵活. 这也就为大型项目.多人协作开发埋下了很多隐患.如果是自己的私有业务倒 ...

  8. [转]Angular项目目录结构详解

    本文转自:https://blog.csdn.net/yuzhiqiang_1993/article/details/71191873 版权声明:本文为博主原创文章,转载请注明地址.如果文中有什么纰漏 ...

  9. Egret入门(三)--创建HelloWorld项目(4.0-使用Egret Wing)

    准备 编辑器: Egret Wing3(4.0.3) 需要下载安装 语言: TepyScript(JS的超集,参考手册http://bbs.egret.com/thread-1441-1-1.html ...

随机推荐

  1. 2019年上半年收集到的人工智能GAN干货文章

    2019年上半年收集到的人工智能GAN干货文章 GAN简介及其常见应用 训练GAN,你应该知道的二三事 了解生成对抗网络(GAN) CosmoGAN:训练GAN,让AI寻找宇宙中的暗物质 关于GAN的 ...

  2. xcode 左边导航栏中,类文件后面的标记“A”,"M","?"……等符号的含义???

        "M" = Locally modified     "U" = Updated in repository   "A" = Loc ...

  3. python:html元素解析

    说明 主要是总结我通过python实现html解析的一个初步的思路和记录实现基础html解析的代码.本解析方式仅仅 只是实现了html按元素解析的功能,具体元素的分类获取还得需要再进行进一步的优化. ...

  4. Hive SQL编译过程(转)

    转自:https://www.cnblogs.com/zhzhang/p/5691997.html Hive是基于Hadoop的一个数据仓库系统,在各大公司都有广泛的应用.美团数据仓库也是基于Hive ...

  5. [Go] gocron源码阅读-go语言web框架Macaron

    gocron源码中使用的是马卡龙框架,下面这个就是安装这个框架,和一般的MVC框架很像go get gopkg.in/macaron.v1git clone https://github.com/go ...

  6. 渗透测试学习 十五、 文件上传&&解析漏洞

    大纲:文件解析漏洞 上传本地验证绕过 上传服务器验证绕过 文件解析漏洞 解析漏洞主要说的是一些特殊文件被IIS.Apache.Nginx在某些情况下解释成脚本文件格式的漏洞. IIS 5.x/6.0解 ...

  7. NGINX动态增加模块,平滑升级

    这是一个小心活,不过,多操作几次,也就熟悉了. 参考URL: https://segmentfault.com/a/1190000006755963 一,安装nginx依赖包. yum install ...

  8. 5. Vue - 小清单实例

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. 日志分析利器Splunk的搭建、使用、破解

    博主对splunk的了解不多,博主的使用目的是为了同步,分析日志.当初的搭建也是为了公司申请牌照需要日志服务器分析日志,顺便自己也对这方面感兴趣就买了本书看了看搭建玩的,后来检查来了博主也给他们演示了 ...

  10. Haproxy+Keepalived构建高可用负载均衡集群

    实验环境: 主机名 IP地址 VIP 192.168.200.254 Haproxy-1 192.168.200.101 Haproxy-2 192.168.200.102 Nginx1 192.16 ...