JavaScript使用Webpack打包前端项目

 更新时间:2026年02月25日 10:10:23   作者:普通网友  
在前端开发中,Webpack作为主流的模块打包工具,能够将各种资源整合为优化的输出文件,这篇文章主要介绍了JavaScript使用Webpack打包前端项目的相关资料,需要的朋友可以参考下

Webpack 配置示例

以下是一个基础的 Webpack 配置示例,用于打包前端项目代码。假设项目包含 JavaScript、CSS 和静态资源(如图片),并支持开发和生产环境的区分。

const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const { CleanWebpackPlugin } = require('clean-webpack-plugin');

module.exports = (env, argv) => {
  const isProduction = argv.mode === 'production';

  return {
    entry: './src/index.js',
    output: {
      filename: isProduction ? '[name].[contenthash].js' : '[name].js',
      path: path.resolve(__dirname, 'dist'),
    },
    module: {
      rules: [
        {
          test: /\.js$/,
          exclude: /node_modules/,
          use: {
            loader: 'babel-loader',
            options: {
              presets: ['@babel/preset-env'],
            },
          },
        },
        {
          test: /\.css$/,
          use: [
            isProduction ? MiniCssExtractPlugin.loader : 'style-loader',
            'css-loader',
            'postcss-loader',
          ],
        },
        {
          test: /\.(png|svg|jpg|gif)$/,
          type: 'asset/resource',
        },
      ],
    },
    plugins: [
      new CleanWebpackPlugin(),
      new HtmlWebpackPlugin({
        template: './src/index.html',
      }),
      ...(isProduction
        ? [
            new MiniCssExtractPlugin({
              filename: '[name].[contenthash].css',
            }),
          ]
        : []),
    ],
    devServer: {
      static: {
        directory: path.join(__dirname, 'dist'),
      },
      hot: true,
    },
  };
};

功能说明

  1. 入口与输出配置

    • 入口文件为 src/index.js,输出到 dist 目录。
    • 生产环境下使用 [contenthash] 实现缓存优化。
  2. 模块处理规则

    • 使用 babel-loader 转译 JavaScript 代码,支持 ES6+ 语法。
    • 通过 css-loaderstyle-loader(开发环境)或 MiniCssExtractPlugin(生产环境)处理 CSS 文件。
    • 使用 asset/resource 类型处理图片等静态资源。
  3. 插件配置

    • CleanWebpackPlugin 在每次构建前清理 dist 目录。
    • HtmlWebpackPlugin 自动生成 HTML 文件并注入打包后的资源。
    • 生产环境下通过 MiniCssExtractPlugin 提取 CSS 为独立文件。
  4. 开发服务器

    • 配置 devServer 支持热更新(HMR)和静态文件服务。

依赖安装

运行以下命令安装所需依赖:

npm install webpack webpack-cli webpack-dev-server --save-dev
npm install babel-loader @babel/core @babel/preset-env --save-dev
npm install css-loader style-loader postcss-loader mini-css-extract-plugin --save-dev
npm install html-webpack-plugin clean-webpack-plugin --save-dev

脚本配置

package.json 中添加以下脚本:

{
  "scripts": {
    "start": "webpack serve --mode development",
    "build": "webpack --mode production"
  }
}

总结 

到此这篇关于JavaScript使用Webpack打包前端项目的文章就介绍到这了,更多相关JS Webpack打包前端项目内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • ES7之Async/await的使用详解

    ES7之Async/await的使用详解

    这篇文章主要介绍了ES7之Async/await的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • JavaScript使用indexOf()实现数组去重的方法分析

    JavaScript使用indexOf()实现数组去重的方法分析

    这篇文章主要介绍了JavaScript使用indexOf()实现数组去重的方法,结合实例形式分析了使用indexOf()方法进行数组的判断与去重相关原理与具体操作技巧,需要的朋友可以参考下
    2018-09-09
  • echarts自定义legend样式的详细图文教程

    echarts自定义legend样式的详细图文教程

    在默认的饼状图里面,图例legend颜色是黑色的,有时候根据ui需要,根据不同的背景色,下面这篇文章主要给大家介绍了关于echarts自定义legend样式的相关资料,需要的朋友可以参考下
    2022-10-10
  • JavaScript中使用typeof运算符需要注意的几个坑

    JavaScript中使用typeof运算符需要注意的几个坑

    这篇文章主要介绍了JavaScript中使用typeof运算符需要注意的几个坑,本文总结了4个使用typeof运算符要注意的问题,需要的朋友可以参考下
    2014-11-11
  • 原生js实现购物车逻辑和功能

    原生js实现购物车逻辑和功能

    这篇文章主要为大家详细介绍了原生js实现购物车逻辑和功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • 解析如何利用iframe标签以及js制作时钟

    解析如何利用iframe标签以及js制作时钟

    本文对如何利用iframe标签以及js制作时钟进行了全面解析,分步说明,条理清晰,感兴趣的朋友可以看下
    2016-12-12
  • js强制把网址设为默认首页

    js强制把网址设为默认首页

    有时候你会发现设首页为失效,那么来一个js强制设置首页的代码,不过为了绿色上网,尽量不要强迫你的用户意志,弄不好网站用户体验会降低。感兴趣的小伙伴可以参考一下
    2015-09-09
  • 关于事件mouseover ,mouseout ,mouseenter,mouseleave的区别

    关于事件mouseover ,mouseout ,mouseenter,mouseleave的区别

    mouseover ,mouseout ,mouseenter,mouseleave,都是鼠标点击而触发的事件,各自代表什么意思,有哪些区别呢?下面跟着脚本之家小编一起看看吧
    2015-10-10
  • javascript 四则运算精度修正函数代码

    javascript 四则运算精度修正函数代码

    JS预算精度问题确实很麻烦,这个能解决一些问题,虽然有bug.
    2010-05-05
  • 微信小程序实现select下拉框

    微信小程序实现select下拉框

    这篇文章主要为大家详细介绍了微信小程序实现select下拉框,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07

最新评论