webpack【初体验】使用 webpack 打包一个程序

打包前

共 3 个文件

dist\index.html

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Webpack 示例</title>
</head>

<body>
    <h1>Webpack 示例</h1>
    <!-- 引入打包后的 JavaScript 文件 -->
    <script src="bundle.js"></script>
</body>

</html>

src\hello.js

cpp 复制代码
export function hello() {
  alert("你好");
}

src\index.js

cpp 复制代码
import { hello } from "./hello";
hello();

使用 Webpack 打包

新建文件 package.json

json 复制代码
{
  "name": "webpack_demo",
  "version": "1.0.0",
  "main": "index.js",
  "scripts": {
    "build": "webpack --config webpack.config.js"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "description": "",
  "devDependencies": {
    "webpack": "^5.97.1",
    "webpack-cli": "^6.0.1"
  }
}

新建文件 webpack.config.js

cpp 复制代码
const path = require("path");

module.exports = {
  // 入口文件
  entry: "./src/index.js",
  // 输出配置
  output: {
    filename: "bundle.js",
    path: path.resolve(__dirname, "dist"),
  },
};

安装依赖

cpp 复制代码
pnpm i

开始打包


打包后

将 hello.js 和 index.js 合并成了一个文件 dist\bundle.js

cpp 复制代码
(()=>{"use strict";alert("你好")})();

最终效果为

浏览器访问 dist\index.html 可见程序正常运行,表示打包成功!

总结 Webpack 的打包过程

  1. Webpack 通过 webpack.config.js 中的 entry 配置,找到打包的入口文件 src/index.js

  2. 沿着入口文件 src/index.js,找到导入的关联文件 src\hello.js

  3. 根据 webpack.config.js 中的 output 配置,Webpack 会将所有找到的文件 ( hello.js 和 index.js )打包成一个名为 bundle.js 的文件,并输出到 dist 文件夹中

  4. dist\index.html 则直接加载的打包后的 bundle.js 文件,实现预期效果

    html 复制代码
        <!-- 引入打包后的 JavaScript 文件 -->
        <script src="bundle.js"></script>
相关推荐
008爬虫实战录10 小时前
【码上爬】 题九:webpack调试 堆栈分析
前端·webpack·node.js
zoomdong11 小时前
@utoo/pack: 基于 Turbopack 的下一代 Rust 构建工具
webpack·rust·开源
下北沢美食家3 天前
Webpack与Vite详解
前端·webpack·node.js
AeahKa3 天前
ztree 依赖问题解决记录
前端·webpack
李白的天不白4 天前
webpack 压缩文件
前端·webpack·node.js
天渺工作室7 天前
构建完自动打包压缩,一个插件搞定 Vite / Webpack / Rollup / ESBuild
webpack·vite·rollup.js
Hello--_--World8 天前
vite:什么是热更新?vite 和 webpack 有什么区别?vite常见配置和优化手段?
前端·webpack·node.js
Hello--_--World8 天前
Vite:什么是bundleless?哪些要打包,哪些不要打包?依赖预构建是什么?依赖预构建如何减少网络请求的?esbuild 又是什么?
前端·javascript·webpack·vite
Rooting++8 天前
vue2+webpack打包优化的相关问题
前端·webpack·node.js
Tatan10 天前
【里程碑二】基于webpack5完成的多前端工程化建设
webpack