12534

之前开发都是在用脚手架,几乎0配置,只需要会ts的语法就完全可以开发ts项目了,这次自己从零折腾了一个ts项目,发现配置方面还是有挺多坑的,所以不如从头看一下具体的方法和文档,于是总结出了这篇文章。相信我,自己系统的了解一遍和使用脚手架直接配置相比,理解上肯定会有不一样的认知。
本文主要从简单的方式了解tsconfig.json是干什么的、怎么用、和webpack结合起来会有一些常见的坑以及一些常用的配置,结合文档来看效果更佳 www.typescriptlang.org/v2/en/tscon…
由于第一次写文章,肯定会有些不严谨或者不好的地方,请大家多多指出建议,谢谢~

用于编译时遵循的规则表

在没有tsconfig的情况下,我们可以用命令行的方式去执行

tsc --outFile file.js --target es3 --module commonjs index.ts

解释上半句:将index.ts用es3的代码和commonjs的形式,编译为file.js在根目录下

  • 需要编译的调调框框很多的情形下(后面将要写一坨)
  • 团队协作的情形下(大家需要有统一的规范)
  • 纯手工命令式

    上文有阐述,得自己打一坨

    配置文件命令式

  • 不显式指定 tsconfig.json ,此时,编译器会从当前路径开始寻,直到找到tsconfig.json文件为止 和require,import不写具体路径的查找规则差不多
  • 通过 --project (或缩写 -p )指定一个包含 tsconfig.json 的路径,和 import,require写个相对路径差不多
  • 配置文件里的具体参数

    配置文件里有很多参数,具体场景有的确实还比较抽象,这里统一举例说明

    这个 tsconfig.json 大体可以分为两个部分描述,第一部分是编译的规则配置(compilerOptions),第二个部分是对哪些文件进行编译(files,include,exclude)

    最常用的结构代码举例如下:

    "compilerOptions": {}, "files": [], "include": [], "exclude": []

    compilerOptions

    顾名思义就是编译规则,下面会具体说一些常用的详细配置

    files

    用法很简单,就是个数组,里面的元素为待编译的ts文件,如下图。

    files就是根据上面编译规则需要将哪些文件编译,举个例子

    上面的配置文件的规则就是将compilerOption的编译规则应用于index.ts下,那如果我下面这样写就肯定会报错了

    所以 得出结论:file适用于比较小型的项目,规定几个特定的文件。

    最后一个小细节,file里面只是入口文件,比如test里面依赖一个 rely.ts 那么在files中不写rely.ts也不会报错。在当前目录下运行一下tsc做比较就知道了~

    那文件很多的项目怎么办,下面的include和exclude就派上用场了

    include && exclude

    当文件有很多的时候,就可以用include和exclude(当然也可以不用)结合使用,比如现在只想让src下的除了带except文件编译,如图所示:

    在该项目根目录输入tsc会发生什么呢?

    会发现并没有编译except.ts的文件

    当用webpack进行打包并暴露出bundle文件的时候会和tsconfig产生冲突,因为他俩都是编译/打包出来的文件,因此要在tsconfig.json中添加exclude到webpack打包出的指定路径,理解如图:

    把注释中的引开就解决这个问题了~

  • include可以和file联用
  • exclude只对include有效,对files无效
  • 如果 files 和 include 都未设置,那么除了 exclude 排除的文件,编译器会默认包含路径下的所有 TS 文件
  • 几个常用的编译配置

    allowJs

    允许编译js文件

    sourceMap

    生成一个.map.js的文件,用于其他工具来debugg,类似于webpack的sourceMap

    noImplicitAny

    不允许用any,如果初学ts,建议项目部太复杂的情况下,可以借此来进行限制,前置自己培养对ts的理解

    module && target

    这两个有一定的关联关系

    target是编译成哪个版本的js(es3,es5,es6...)

    module模板生成的形式,默认情况下,当target是es3的时候,那module默认为commonjs形式,否则为es6形式。

    注意(和outFile搭配使用) :生成的模块形式:none、commonjs、amd、system、umd、es6、es2015 或 esnext 只有 amd 和 system 能和 outFile 一起使用 target 为 es5 或更低时可用 es6 和 es2015

    引入ES的功能库,比如想在项目中用js中Set,Map等新的数据结构,或promise等,那要在lib中引入es2015

    removeComments

    编译出的文件是否带注释,当为false的时候可以减少编译出文件的体积

    allowSyntheticDefaultImports

    这个配置挺重要的,如果不知道会很纳闷,不好排查为啥会报错

    当它为false的时候,引入模块的时候必须以*as的形式,例如引入react

    import * as React from 'react'

    当为true的时候

    import React from 'react' 但要注意,他要配合module是esModule的格式或者--esModuleInterop为true的时候,因为react是commonjs写的,并没有default,所以import React from 这种default引入是不对的,具体可以看下这篇文章 blog.leodots.me/post/40-thi…

    如果用tsx文件(React-ts)那么该项要配置成 jsx:"react"

    baseUrl

    举个例子:

    在根目录的src目录有个hello文件夹,其中hello里包含world.ts

    在根目录的app.ts下

    import { example } from "./src/hello/world"

    当baseUrl: './src'

    则上面的目录可以简写成 import { example } from "hello/world"

    paths

    paths必须和上面的baseUrl联用,举个例子:

    那么将可以这样引入:

    但是有一点必须要特别注意:

    如果用了webpack使用了alias,那么导致baseUrl不会生效,从而paths也不会生效,所以paths岂不是没用了吗?其实从实际作用来说确实是没用了, 不过可以将paths的配置和alias配置成一样的,在vscode中会有路径的自动提示,也是很方便很爽的

    分类:
    前端
    标签: