TypeScript 的编译配置 + webpack打包

// 热更新的ts文件

·
单个文件的热更新: tsc 文件名.ts -watch | -w
​ 多个文件的热更新: 在根目录下创建一个tsconfig.json 的文件, tsc -w 后即可热更新

// tsconfig.json的配置选项

include: 指定编译的文件

​ ** : 表示任意路径

​ * : 表示任意文件

    "include": [ "./src/**/*" ] // => 根目录下的src文件中的任意路径(**)的任意文件(*)

exclude: 不需要编译的文件

"exclude": ["node_modules", "bower_components", "jspm_packages"] // 默认值

extends: 定义被继承的配置文件

"extends":  "./configs/base" // => 是指引入在configs中的base.json的文件

files: 指定被编译文件的列表,*只有需要编译的文件少时才会用

// **compilerOptions: ** 编译器的选项

​ **target: ** 用于指定TS被解析的ES的版本

    "target": "es2015" // 可选项 "es3", "es5", "es6", "es2015", "es2016", "es2017", "es2018", "es2019", "es2020", "esnext"

module: 指定es的模块化方案

    "module": "es2015" // 可选项: "none", "commonjs", "amd", "system", "umd", "es6", "es2015", "es2020", "esnext"

lib: 依赖的库,一般不需要修改

    "lib":  [] /* 'es5' 'es6' 'es2015' 'es7' 'es2016' 'es2017' 
'es2018' 'es2019' 'es2020' 'esnext' 'dom' 'dom.iterable' 'webworker' 'webworker.importscripts' 'scripthost' 'es2015.core' 'es2015.collection' 'es2015.generator' 'es2015.iterable' 'es2015.promise' 'es2015.proxy' 'es2015.reflect' 'es2015.symbol' 'es2015.symbol.wellknown' 'es2016.array.include' 'es2017.object' 'es2017.sharedmemory' 'es2017.string' 'es2017.intl' 'es2017.typedarrays' 'es2018.asyncgenerator' 'es2018.asynciterable' 'es2018.intl' 'es2018.promise' 'es2018.regexp' 'es2019.array' 'es2019.object' 'es2019.string' 'es2019.symbol' 'es2020.bigint' 'es2020.promise' 'es2020.string' 'es2020.symbol.wellknown' 'esnext.array' 'esnext.symbol' 'esnext.asynciterable' 'esnext.intl' 'esnext.bigint' 'esnext.string' 'esnext.promise' */

outDir: 用于存放编译后的文件所在目录

    "outDir": "./dist"

outFile: 设置outFile后 会吧所有的文件合并到同一个文件中并且 只有符合"amd",和"system" 模块化的文件才能合并到同一个文件

    "outFile": "./dist/app"

allowJs: true // 是否编译JS

checkJs: true // 是否校验符合Ts语法的JS

​ * 一般都是同时 使用 均为布尔值

removeComments: true // 是否编译注释

noEmit: false // 不生成编译后的文件

noEmitOnError: true // 不编译错误的文件

alwaysStrict: true // 用于编译后的js文件是否使用严格模式(模块代码自带严格模式)

noImplicitAny: true // 不允许变量没有数据类型(即:不声明变量的数据类型,默认为:any)

noImplicitThis: true // 不允许不明确类型的this(即:需要标注this的来源或者类型)

function fn(this: window) {
    console.log(this)
}

strictNullChecks: true // 严格检测空值

strict: true // 所有严格选项的总开关

// webpack打包TS

初始化项目: npm init -y 创建package.json文件

安装依赖: npm i -D webpack webpack-cli typescript ts-loader html-webpack-plugin webpack-dev-server clean-webpack-plugin

  *  -D : 开发版;
  *  webpack-cli: webpack命令行   
  *  ts-loader: webpack的整合器,使ts编译与之一体
  *  html-webpack-plugin:webpack中html插件,用来自动创建html文件
  *  webpack-dev-server: webpack开发服务
  *  clean-webpack-plugin:webpack中的清除插件,每次build都会先清除目录

配置webpack: 根目录下创建webpack的配置文件webpack.config.js

  • environment // 打包配置后 (打包后不使用箭头函数)
// 引入包
const path = require("path")
// 引入 webpack 的 html 插件
const HTMLWebpackPlugin = require("html-webpack-plugin")
// 引入build时删除的dist的插件
const { CleanWebpackPlugin } = require('clean-webpack-plugin')
// webpack的锁头配置文件都要写在 module.exports 中
module.exports = {
  // 指定入口文件
  entry: "./src/index.ts" ,
  // 指定到打包后的文件目录
  output: {
    path: path.resolve(__dirname, 'dist'),
    // 打包后的文件的文件
    filename: "bundle.js",
      
    // 打包配置后 (打包后不使用箭头函数)
    environment: {
      arrowFunction: true // 兼容IE11一下
    }
      
  },
  // 指定webpack打包时使用的模块
  module: {
    // 指定打包后的规则
    rules: [
      {
        // test 指定生效的文件
        test: /\.ts$/,
        // 使用 ts-loader 编译所有的 .ts的文件
        use: [
          // 配置babel
          {
            // 指定加载器
            loader: "babel-loader",
            options: {
              // 设置预定义的运行环境
              presets: [
                [
                  // 指定环境的插件
                  "@babel/preset-env",
                  // 配置信息
                  {
                    // 要兼容的浏览器版本
                    targets: {
                      "chrome": "58",
                      "ie": "11"
                    },
                    // 指定corejs的版本
                    "corejs": "3",
                    // 使用corejs的方式: usage=>按需加载
                    "useBuiltIns": "usage"
                  }
                ]
              ]
            }
          },
          'ts-loader'
          ],
        // 要排除的文件
        exclude: /node_modules/
      }
    ]
  },
  plugins: [
    new CleanWebpackPlugin(),
    // 创建html插件实例
    new HTMLWebpackPlugin({
        // 网页模板 
        template: "./src/index.html"
      }),
  ],
  // 设置可引用的模块
  resolve: {
    extensions: ['.ts', '.js']
  }
}

配置TS编译选项: 根目录下创建tsconfig.json,(配置可以根据自己需要)

{
   "compilerOptions": {
       "target": "ES2015",
       "module": "ES2015",
       "strict": true
   }
}

修改package.json配置: 添加build与start

{
   ...
   "scripts": {
       "test": "echo \"Error: no test specified\" && exit 1",
       "build": "webpack",
       "start": "webpack serve --open chrome.exe"
   },
   ...
}

项目启用: 在src下创建ts文件,并在并命令行执行npm run build对代码进行编译;或者执行npm start来启动开发服务器;

// babel包

​ 作用:用于兼容各个版本的浏览器

​ 安装: npm i @babel/core @babel/preset-env babel-loader core-js

​ * @babel/core: babel主要库

​ * @babel/preset-env: babel预置环境 (适应不同浏览器)

​ * babel-loader: 合并包

​ * core-js: js运行环境 (模拟不同的版本浏览器)

  • babel配置在上方webpack.config.js
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,718评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,683评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,207评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,755评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,862评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,050评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,136评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,882评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,330评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,651评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,789评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,477评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,135评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,864评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,099评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,598评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,697评论 2 351

推荐阅读更多精彩内容