TypeScript打包webpack基本配置(合集tsconfig.json、webpack.config.js、package.json)

基本适用于基础框架的搭建

webpack.config.js

javascript 复制代码
// pnpm i -D webpack webpack-cli typescript ts-loader //打包配置所需要插件
// pnpm i -D html-webpack-plugin//会自动生成html文件
// pnpm i -D webpack-dev-server //会自动刷新(热更新)
// pnpm i -D clean-webpack-plugin //每次打包会自动删除dist旧文件
// pnpm i -D @babel/core @babel/preset-env babel-loader core-js //老版本浏览器兼容

// 引入包
const path = require('path');
// 引入html插件
const HtmlWebpackPlugin = require('html-webpack-plugin');
// 引入clean插件
const { CleanWebpackPlugin } = require('clean-webpack-plugin');


// webpack所有的配置信息都应该写在module.exports中
module.exports = {
  // 配置对象
  // 1. 入口文件
  entry: './src/index.ts',
  // 2. 输出文件
  output: {
    // 输出文件的路径
    path: path.resolve(__dirname, 'dist'),
    // 输出文件的名称
    filename: 'bundle.js',
    // 告诉webpack,不使用箭头函数
    environment: {
      arrowFunction: false
    }
  },
  // 3. 配置loader(指定webpack打包时要使用的模块)
  module: {
    // 指定要加载的规则
    rules: [
      {
        // ts指定的是规则生效的文件
        test: /\.ts$/,
        // 要使用的loader
        use: [
          // 配置babel
          {
            // 指定加载器
            loader: 'babel-loader',
            // 设置babel
            options: {
              presets: [
                [
                  // 指定环境插件
                  "@babel/preset-env",
                  // 配置信息
                  {
                    // 要兼容的目标浏览器
                    targets: {
                      "chrome": "58",
                      "ie": "11"
                    },
                    // 指定corejs的版本
                    "corejs": "3",
                    // 使用corejs的方式 "usage" 表示按需加载
                    "useBuiltIns": 'usage'
                  }
                ]
              ]
            }

          }, 'ts-loader'],
        // 要排除的文件
        exclude: /node_modules/
      }
    ]
  },
  // 配置webpack插件
  plugins: [
    new HtmlWebpackPlugin({
      // title: '自定义title'
      template: './src/index.html'//自定义网页模版
    }),
    new CleanWebpackPlugin()
  ],
  // 用来设置引用模块(设置以这些结尾的可以按照模块导出的方式引用)
  resolve: {
    extensions: ['.js', '.ts']
  }

}

tsconfig.json

javascript 复制代码
{
  "compilerOptions": {
    "target": "ES2015",
    "module": "ES2015",
    "strict": true
  }
}

package.json

javascript 复制代码
{
  "name": "part3",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "build": "webpack",
    "start": "webpack serve --open chrome.exe"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "@babel/core": "^7.24.7",
    "@babel/preset-env": "^7.24.7",
    "babel-loader": "^9.1.3",
    "clean-webpack-plugin": "^4.0.0",
    "core-js": "^3.37.1",
    "html-webpack-plugin": "^5.6.0",
    "ts-loader": "^9.5.1",
    "typescript": "^5.5.3",
    "webpack": "^5.92.1",
    "webpack-cli": "^5.1.4",
    "webpack-dev-server": "^5.0.4"
  }
}
相关推荐
前端李二牛27 分钟前
异步任务并发控制
前端·javascript
你也向往长安城吗1 小时前
推荐一个三维导航库:three-pathfinding-3d
javascript·算法
karrigan1 小时前
async/await 的优雅外衣下:Generator 的核心原理与 JavaScript 执行引擎的精细管理
javascript
wycode1 小时前
Vue2实践(3)之用component做一个动态表单(二)
前端·javascript·vue.js
wycode2 小时前
Vue2实践(2)之用component做一个动态表单(一)
前端·javascript·vue.js
第七种黄昏2 小时前
Vue3 中的 ref、模板引用和 defineExpose 详解
前端·javascript·vue.js
我是哈哈hh3 小时前
【Node.js】ECMAScript标准 以及 npm安装
开发语言·前端·javascript·node.js
张元清3 小时前
电商 Feeds 流缓存策略:Temu vs 拼多多的技术选择
前端·javascript·面试
pepedd8643 小时前
浅谈js拷贝问题-解决拷贝数据难题
前端·javascript·trae
@大迁世界3 小时前
useCallback 的陷阱:当 React Hooks 反而拖了后腿
前端·javascript·react.js·前端框架·ecmascript