详解 配置webpack打包typescript

2 篇文章 0 订阅
1 篇文章 0 订阅

全局安装 TypeScript:

npm install -g typescript

安装完成后,在控制台运行如下命令,检查安装是否成功

tsc -V

下载依赖

安装依赖涉及版本问题,确保各个版本之间必须兼容

yarn add -D typescript  安装ts
yarn add -D webpack webpack-cli  脚手架
yarn add -D webpack-dev-server  启动工具
yarn add -D html-webpack-plugin clean-webpack-plugin  html打包、清理包工具
yarn add -D ts-loader  编译ts
yarn add -D cross-env  涉及跨平台命令

使用版本:

创建目录

入口JS: src/main.ts

document.write('Hello Webpack TS!')

index页面: public/index.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>webpack & TS</title>
</head>
    <body></body>
</html>

build/webpack.config.js

const {CleanWebpackPlugin} = require('clean-webpack-plugin')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const path = require('path')

const isProd = process.env.NODE_ENV === 'production' // 是否生产环境

function resolve (dir) {
  return path.resolve(__dirname, '..', dir)
}

module.exports = {
  mode: isProd ? 'production' : 'development',
  entry: {
    app: './src/main.ts'
  },

  output: {
    path: resolve('dist'),
    filename: '[name].[contenthash:8].js'
  },

  module: {
    rules: [
      {
        test: /\.tsx?$/,
        use: 'ts-loader',
        include: [resolve('src')]
      }
    ]
  },

  plugins: [
    new CleanWebpackPlugin({
    }),

    new HtmlWebpackPlugin({
      template: './public/index.html'
    })
  ],

  resolve: {
    extensions: ['.ts', '.tsx', '.js']
  },

  devtool: isProd ? 'cheap-module-source-map' : 'cheap-module-eval-source-map',

  devServer: {
    host: 'localhost', // 主机名
    stats: 'errors-only', // 打包日志输出输出错误信息
    port: 8081,
    open: true
  },
}

初始化项目npm init -y

自动生成package.json

 

初始化 tsc --init

自动生成tsconfig.json

 

配置打包命令

 

"dev": "cross-env NODE_ENV=development webpack-dev-server --config build/webpack.config.js",
"build": "cross-env NODE_ENV=production webpack --config build/webpack.config.js"

运行与打包

yarn dev
yarn build

运行成功

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Webpack是一个模块打包器,可以将多个模块打包成一个静态资源文件。前端使用webpack可以实现代码的模块化、压缩、合并、懒加载等功能,提高网站的性能和用户体验。 以下是前端配置webpack打包的步骤: 1. 安装webpackwebpack-cli 在项目根目录下执行以下命令: ``` npm install webpack webpack-cli --save-dev ``` 2. 创建webpack配置文件 在项目根目录下创建webpack.config.js文件,并配置入口文件和输出文件: ```javascript const path = require('path'); module.exports = { entry: './src/index.js', output: { filename: 'bundle.js', path: path.resolve(__dirname, 'dist') } }; ``` 3. 配置loader 使用loader可以对不同类型的文件进行处理,如将ES6代码转换成ES5代码、将CSS文件打包进JS文件中等。在webpack.config.js文件中添加以下配置: ```javascript module.exports = { // ... module: { rules: [ { test: /\.js$/, exclude: /node_modules/, use: { loader: 'babel-loader', options: { presets: ['@babel/preset-env'] } } }, { test: /\.css$/, use: ['style-loader', 'css-loader'] } ] } }; ``` 上面的配置中,使用babel-loader对JS文件进行ES6转ES5的处理,使用css-loader和style-loader对CSS文件进行打包。 4. 配置插件 使用插件可以对打包后的文件进行优化、压缩等处理。在webpack.config.js文件中添加以下配置: ```javascript const HtmlWebpackPlugin = require('html-webpack-plugin'); const { CleanWebpackPlugin } = require('clean-webpack-plugin'); module.exports = { // ... plugins: [ new CleanWebpackPlugin(), new HtmlWebpackPlugin({ template: './src/index.html' }) ] }; ``` 上面的配置中,使用CleanWebpackPlugin插件清理dist目录下的旧文件,使用HtmlWebpackPlugin插件生成HTML文件。 5. 运行webpack 在项目根目录下执行以下命令: ``` npx webpack ``` 执行命令后,webpack将会读取webpack.config.js文件并进行打包。 以上就是前端配置webpack打包的步骤。配置完成后,可以通过修改webpack.config.js文件来实现更多的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值