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打包前端项目内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 用javascript模仿ie的自动完成类似自动完成功的表单

    用javascript模仿ie的自动完成类似自动完成功的表单

    最近在写一个javascript框架,看见网上有不少自动完成功能的表单,于是用javascript写了一个,需要的朋友可以参考下
    2012-12-12
  • javascript中Promise的三种状态示例详解

    javascript中Promise的三种状态示例详解

    这篇文章主要给大家通过讲解和实践,详细介绍了Promise对象的三种状态:pending(待定)、fullfilled(已兑现)、rejected(已拒绝),并通过日志查看,展示了Promise状态的改变顺序,帮助读者更好的理解和应用Promise,需要的朋友可以参考下
    2024-10-10
  • JavaScript知识点整理

    JavaScript知识点整理

    本文是脚本之家小编日常整理的关于javascript知识点,包括javascript拥有的特点,组成部分,数据类型等方面,对javascript知识点相关知识感兴趣的朋友一起学习吧
    2015-12-12
  • JS中for...in 和 for...of 的区别解析

    JS中for...in 和 for...of 的区别解析

    for … in 用于迭代对象的可枚举字符串属性,包括自身属性和继承的属性,但不会遍历对象的原型链上的 非可枚举属性,以及对象的方法,这篇文章主要介绍了JS中for...in 和 for...of 的区别,需要的朋友可以参考下
    2024-03-03
  • JS实现汉字与Unicode码相互转换的方法详解

    JS实现汉字与Unicode码相互转换的方法详解

    这篇文章主要介绍了JS实现汉字与Unicode码相互转换的方法,结合实例形式较为详细的分析了javascript针对汉字与Unicode编码转换的操作技巧与相关注意事项,需要的朋友可以参考下
    2017-04-04
  • JS实现复选框的全选和批量删除功能

    JS实现复选框的全选和批量删除功能

    本文主要介绍了JS实现复选框的全选和批量删除功能的方法代码。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-04-04
  • 解决给dom元素绑定click等事件无效问题的方法

    解决给dom元素绑定click等事件无效问题的方法

    本文主要介绍了解决给dom元素绑定click等事件无效问题的方法。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-02-02
  • js预加载图片方法汇总

    js预加载图片方法汇总

    这篇文章主要介绍了js预加载图片方法,实例汇总了javascript实现预加载图片的常用技巧,需要的朋友可以参考下
    2015-06-06
  • TS 中 never,void,unknown类型详解

    TS 中 never,void,unknown类型详解

    这篇文章主要介绍了TS 中 never,void,unknown类型详解,never 类型是 TypeScript 中的底层类型,unknown是TypeScript中比较特殊的一种类型,它用于描述类型不确定的变量,本文给大家介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • ECharts数据可视化基本使用之常用图表类型

    ECharts数据可视化基本使用之常用图表类型

    这篇文章主要给大家介绍了关于ECharts数据可视化基本使用之常用图表类型的相关资料,echarts是一款基于JavaScript的数据可视化图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表,需要的朋友可以参考下
    2023-11-11

最新评论