让你的项目使用Ts吧
9012年都过半了,还不会用ts你就out了
why ?
- 三大框架angular2以后的版本完全是用ts开发的,
- vue对ts的支持也越来越好,
- 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
截至第二步, 每次修改文件你都要执行两步:
- 编译文件 tsc
- 执行文件 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吧的更多相关文章
- vsCode怎么为一个前端项目配置ts的运行环境
vsCode为一个前端项目配置ts的运行环境,ts文件保存的时候自动编译成js文件: 假设此前端项目名称为Web:文件结构如图 1. 在根目录中新建一个“.vscode”文件夹,里面建一个“tasks ...
- angular项目中ts的配置编译tsconfig.json
{ "compilerOptions": { /* 基本选项 */ "target": "es5", // 指定 ECMAScript 目标 ...
- angular4.0项目main.ts详解
main.ts负责引导整个angular应用的起点 // 导入enableProdMode用来关闭angular开发者模式 import { enableProdMode } from '@angul ...
- 公共项目开发:我为什么用 JSDoc,而不用 ts
公共模块,通常会被多个项目.不同的开发人员使用,所以开发公共模块时,你自己会用还不够,要让所有人都能很快的知道怎么去使用,这一点很关键.通常会从3个方面做到这点: 精心分割代码逻辑,遵循开闭原则: 变 ...
- vue项目中使用ts(typescript)入门教程
最近项目需要将原vue项目结合ts的使用进行改造,这个后面应该是中大型项目的发展趋势,看到一篇不错的入门教程,结合它并进行了一点拓展记录之.本文从安装到vue组件编写进行了说明,适合入门. 1.引入T ...
- 视音频编解码学习工程:TS封装格式分析器
=====================================================视音频编解码学习工程系列文章列表: 视音频编解码学习工程:H.264分析器 视音频编解码学习工 ...
- 原有vue项目接入typescript
原有vue项目接入typescript 为什么要接入typescript javascript由于自身的弱类型,使用起来非常灵活. 这也就为大型项目.多人协作开发埋下了很多隐患.如果是自己的私有业务倒 ...
- [转]Angular项目目录结构详解
本文转自:https://blog.csdn.net/yuzhiqiang_1993/article/details/71191873 版权声明:本文为博主原创文章,转载请注明地址.如果文中有什么纰漏 ...
- Egret入门(三)--创建HelloWorld项目(4.0-使用Egret Wing)
准备 编辑器: Egret Wing3(4.0.3) 需要下载安装 语言: TepyScript(JS的超集,参考手册http://bbs.egret.com/thread-1441-1-1.html ...
随机推荐
- MySQL基础之数据管理【1】
添加记录 insert [into] tbl_name[(col_name,...)] {value|values}(values...); --不指定字段名称时需要按照建表时的字段顺序给每一个字段赋 ...
- 炫彩字and鼠标爱心
<!DOCTYPE html> <style type="text/css"> body{ background-color: black; } #zx { ...
- Windows Cluster失败后,AlwaysOn在残存Server节点上快速恢复DB的详细步骤
AlwaysOn是一种集合了高可用和灾难恢复两种功能的技术,它支持一个或多个数据库整体的发生故障转移,它实现了一定程度上的负载均衡,减轻了主服务器的压力,是目前最好的一种选择.那么当极端情况发生时,集 ...
- Hive性能调优(一)----文件存储格式及压缩方式选择
合理使用文件存储格式 建表时,尽量使用 orc.parquet 这些列式存储格式,因为列式存储的表,每一列的数据在物理上是存储在一起的,Hive查询时会只遍历需要列数据,大大减少处理的数据量. 采用合 ...
- mysql-python 安装错误 fatal error C1083: Cannot open include file: 'config-win.h': No such file or directory
安装mysql-python之前, 请先安装setuptools. https://pypi.python.org/pypi/setuptools/7.0 下载mysql-python. 下载源码包. ...
- emacs 帮助相关命令
emacs 帮助相关命令 如下表: No. 键盘操作 键盘操作对应的函数 回答的问题 01 ctrl-h c describe-key-briefly 这个按键组合将运行哪个函数 02 ctrl-h ...
- 不懂这个别说是刷机高手!安卓Recovery你知多少
[PConline 应用]玩过安卓刷机的朋友相信都听说过Recovery,在刷机前,第一步往往是解锁手机,第二部就是刷入Recovery了.利用Recovery读取第三方Rom并刷入系统,才能实现刷机 ...
- 5-7 可视化库Seaborn-热度图绘制
In [1]: %matplotlib inline import numpy as np import matplotlib.pyplot as plt import seaborn as sns ...
- Vue生命周期钩子---2
vue生命周期简介 咱们从上图可以很明显的看出现在vue2.0都包括了哪些生命周期的函数了. 生命周期探究 对于执行顺序和什么时候执行,看上面两个图基本有个了解了.下面我们将结合代码去看看钩子函数的执 ...
- lua 4 使用table实现其他数据结构,并介绍遍历方法
本文会以vector / map / set 这三种数据类型的角度来梳理 table 支持的不同遍历方式. table as std::vector 一般,C/C++中的 array / vector ...