超详细的webpack之开始体验吧

webpack是一个前端工程化非常重要静态模块化打包工具,可以帮我们把 less、sass、esmodule、commonjs 等模块依赖处理成浏览器可识别的静态资源。

虽然webpack非常好用,但它可配置项和语法非常的多,还是比较难理解和掌握的,让我们从最基础的开始,一步步体验吧~

不使用webpack时

浏览器可以识别部分js代码,即使没有webpack,我们代码也是能够运行在浏览器端的。

使用esmodule来做一个演示,新建一个 demo 文件夹,demo 文件夹内新建 src 文件夹和 index.html 文件,src 文件夹里有 util 文件夹和 index.js 文件,util 文件夹中新增 math.js 文件,项目结构如下

demo
├─ src
│     ├─ util
│     │    └─ math.js
│     ├─ index.js
└─ index.html

在math.js中使用模块化导出方法,index.js中导入,并在index.html中通过script标签引入index.js,注意这里的script标签要增加type="module",表示模块化

// math.js
function add(a, b) {
  return a + b;
}
function sub(a, b) {
  return a - b;
}
export { add, sub };

// index.js
import { add, sub } from "./utils/math.js";
console.log(add(20, 30));
console.log(sub(20, 30));

// index.html
<script src="./src/index.js" type="module"></script>
2_type=module.png

说明esmodule是可以被浏览器识别的,但如果我们只修改导入导出方式,改为commonjs时,浏览器就不能识别了

// math.js
- export { add, sub };
+ module.exports = {
+  add,
+  sub,
+ };

// index.js
- import { add, sub } from "./utils/math.js";
+ const { add, sub } = require("./utils/math.js");

浏览器是不能识别commonjs语法的,所以会报错

3_无法识别commonjs.png

也就是说浏览器对于某些特定的语法并不支持,虽然可以选择commonjs用于浏览器端的一些方案,但通过单一的方式解决了这个问题,仍可能存在其它语法的解析问题,为了处理所有语法兼容问题,使用一种通用的解决方式,webpack来统一处理浏览器对于某些语法不能解析的问题~

使用webpack

首先要全局安装webpack和webpack-cli

npm i webpack webpack-cli -g

webpack 会对我们编写的代码进行编译,下面表示已经编译了 index.js 和 math.js 文件,虽然有“warning”警告,但仍然是编译成功了的。

4_webpack编译.png

可在上面的代码中我们并没有告知webpack该对哪个文件进行编译,以及最终编译到哪个文件夹中,怎么就能直接编译成功呢?

其实它自身是有默认的编译规则的,将 src 文件夹下的 index.js 文件,以及index.js文件所用到的其它js文件的代码编译至 dist 文件夹下的 main.js 文件。

5_编译后main.png

我们在index.html中引入main.js文件看到编译后的结果啦~ 和上面使用 esmodule 导出的打印结果是一致的

初始化

要进一步体验webpack,需要依赖于node,在刚刚的demo文件夹根目录通过 npm init -y 初始化node项目,生成 package.json 文件。

在项目中再安装 webpack 和 webpack-cli,与全局版本 5.70.0 做区分,我们指定安装 5.60.0 版本 npm i webpack@5.60.0 -D

全局和项目中安装了 webpack 的情况下,直接执行 webpack 来看看使用的是哪个版本。

6_webpack版本.png

仍然使用的是全局的 webpack 版本,当项目与全局webpack版本不一致时,可能会出现一些问题,那我们可以通过以下方式获取到项目中webpack版本。

  • 直接找到项目 node_modules 目录下 .bin 文件夹的 webpack 指令 ./node_modules/.bin/webpack
  • 使用npx指令来执行 node_modules 下的命令 npx webpack
  • 在package.json里的"script"中定义指令
    "script": {
        "build": "webpack"
    }   
    
    然后通过 npm run build来执行

先在项目中通过 npm i webpack-cli -D 安装 webpack-cli ,然后就可以通过以上任意一种方式执行项目中的webpack

7_执行项目中的webpack.png

命令行

webpack 对文件进行编译时默认查找有两条规则,如果都不符合,将无法编译成功

  • 查找 src 文件夹下的 index.js 文件
  • 执行 webpack.config.js 文件

将 index.js 文件名改为 main.js 后,编译就报错了

8_找不到indexjs文件.png

有时候我们的项目结构不一定能和webpack默认编译的规则保持一致,这时候可以通过命令行自定义编译规则

比如指定导入路径 --entry 文件名 ,指定导出文件夹 --output-path 文件名

9_命令行.png

也可以定义在 package.json 中

"script": {
   “build”:“webpack --entry ./src/main.js --output-path ./build”
}

然后通过 npm run build来执行

我们可能会有很多处规则需要自定义,包括解析模块的入口,出口,以及其它资源解析方式,如果通过命令行或者package.json,可读性会很差,所以我们通过一个单独的js文件来定义。

webpack.config.js

定义webpack.config.js 文件,指定编译入口为 src 下的 main.js,出口为 dist 文件夹下的 bundle.js,再通过 module.exports 将定义的配置导出。

这里有两点需要注意

  • webpack是在node环境下解析的,所以需要通过 commonjs 的导出方式
  • 编译入口可以使用相对路径,但出口需要使用绝对路径,通过 _diname 获取
    当前文件所在的目录的绝对路径
const path = require("path");

module.exports = {
  entry: "./src/main.js",
  output: {
    filename: "./bundle.js",
    path: path.resolve(__dirname, "./dist"),
  },
};

配置完成后就可以直接通过 npx webpack 来编译啦

10_webpackconfigjs文件.png

这里也可以修改配置文件的名称,比如修改成 wk.config.js,也是可以通过 命令行 npx webpack --config wk.config.js 或者 package.json 中配置 build 规则来执行

11_更改配置文件名称.png

依赖图

12_webpack图结构.png

webpack在处理应用程序时,它会根据命令或者配置文件找到入口文件,从入口开始,会生成一个依赖关系图,这个依赖关系图会包含应用程序中所需的所有模块 (比如.js文件、css文件、图片、 字体等),然后遍历图结构,打包一个个模块。

以上我们对webpack进行了初体验,后面还有很多的配置规则,loader、plugin、source-map等等,持续更新中~

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,692评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,482评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,995评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,223评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,245评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,208评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,091评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,929评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,346评论 1 311
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,570评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,739评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,437评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,037评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,677评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,833评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,760评论 2 369
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,647评论 2 354

推荐阅读更多精彩内容