0%

初识webpack

基础

webpack 是什么

webpack 可以分析你的项目结构,找到 JavaScript 模块以及其它的一些浏览器不能直接运行的拓展语言(Scss,TypeScript 等),并将其打包为合适的格式以供浏览器使用

webpack 学习路线

alt webpack路线

webpack 基础用法,概念

entry

entry 用来配置入口文件的地址,支持三种写法

1.字符串

1
entry: path.resolve(__dirname, "src/index.js")

打包后生成 main.js
2.对象

1
2
3
4
entry: {
main: path.resolve(__dirname, "src/index.js"),
index: path.resolve(__dirname, "src/main.js"),
}

打包后生成 main.js,index.js

3.数组

1
2
3
4
entry: [
path.resolve(__dirname, "src/index.js"),
path.resolve(__dirname, "src/main.js"),
]

打包后生成 main.js
如果key不指定名称默认 main.js,其中数组写法等价对象 key-value

output

output 用来配置出口文件的地址

1
2
3
4
output: {
path: path.resolve(__dirname, "dist"),
filename: "[name].[hash].js",
},
mode

mode 支持三种种模式:分别是 production,development,none

  • mode为production时,会启用各种性能优化的功能,包括构建结果优化以及 webpack 运行性能优化
  • mode为development时,则会开启 debug 工具,运行时打印详细的错误信息,以及更加快速的增量编译构建
status

status 用来控制命令行展示的信息地址

1
2
3
4
5
6
stats: {
modules: false,
children: false,
chunks: false,
chunkModules: false,
}

我配置的modules,children,chunks,chunkModules都不显示看起来信息没那么多
如图status

optimization
performance

展示性能提示

1
2
3
4
5
6
7
8
performance: {
// false | "error" | "warning"
hints: "warning",
// 根据入口起点的最大体积,控制webpack何时生成性能*提示,整数类型,以字节为单位
maxEntrypointSize: 5000000,
// 最大5m
maxAssetSize: 1024 * 1024 * 5,
}
resolve解析

常用到的两个
1.extensions
指定extension之后可以不用在require或是import的时候加文件扩展名,会依次尝试添加扩展名进行匹配

1
extensions: [".js", "vue", ".jsx", ".json", ".css"]

2.alias
设置别名

1
2
3
alias: {
"@": path.resolve(__dirname, "../src"), // 这样配置后 @ 可以指向 src 目录
}
module

import,require,define ,css/sass/less 文件中的 @import==引过来的

文件指纹
1.hash

hash 是以项目为入口生成的,每次编译都会重新生成

2.chunckhash

chunckhash 根据不同的入口文件(Entry)进行依赖文件解析、构建对应的 chunk,生成对应的哈希值

3.contenthash

contenthash 主要是为了应对 js 引入 css 文件,js 改变 css 的 hash 也跟着改变这种情况的,contenthash 可以在 js 中引入 css,只改变 js 的时候不改变 css 的 hash

sourcemap

sourcemap 是为了解决运行浏览器运行时帮助我们 debug 到原始开发代码
devtool

plugin
  • 常用 plugin
    copy-webpack-plugin
    clean-webpack-plugin
    webpack-bundle-analyzer
loader
1.loader 是干什么的

loader 是转换器,可以要把不同的文件都转成浏览器认识的 js,css==

2.loader 用法
  • loader
1
2
3
4
5
6
rules: [
{
test: /\.css/,
loader:['style-loader','css-loader']
}
]
  • use
1
2
3
4
5
6
rules: [
{
test: /\.css/,
use:['style-loader','css-loader']
}
]
  • use+loader
1
2
3
4
5
6
7
8
9
10
11
12
rules: [
{
test: /\.css/,
include: path.resolve(__dirname,'src'),
use: [{
loader: 'style-loader',
options: {
insert:'top'
}
},'css-loader']
}
]
externals

打包成 umd,结构目录

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
! function (e, o) {
if ("object" == typeof exports && "object" == typeof module) module.exports = o(require("jQuery"));
else if ("function" == typeof define && define.amd) define(["jQuery"], o);
else {
var n = "object" == typeof exports ? o(require("jQuery")) : o(e.jQuery);
for (var t in n)("object" == typeof exports ? exports : e)[t] = n[t]
}
}(window, (function (e) {
return (window.webpackJsonp = window.webpackJsonp || []).push([[0], [function (o, n) {
o.exports = e
}, function (e, o, n) {}, function (e, o, n) {
"use strict";
n.r(o), o.default =
""
}, , , , function (e, o, n) {
"use strict";
n.r(o);
n(0), n(1);
var t = function (e, o) {
return e + o
};
t(1, 22), n(3).defaults({
a: 1
}, {
a: 3,
b: 2
}), t(1, 2);
var A = document.getElementById("app"),
a = document.createElement("div"),
s = document.createDocumentFragment(),
u = new Image;
u.className = "pidan", u.src = n(2).default, a.className = "dog", s.appendChild(a), s.appendChild(
u), A.appendChild(s)
}], [[6, 1, 2]]])
}));

其中

1
2
3
4
5
6
if ("object" == typeof exports && "object" == typeof module) module.exports = o(require("jQuery"));
else if ("function" == typeof define && define.amd) define(["jQuery"], o);
else {
var n = "object" == typeof exports ? o(require("jQuery")) : o(e.jQuery);
for (var t in n)("object" == typeof exports ? exports : e)[t] = n[t]
}

主要用来区分运行时用的哪种规范

webpack 打包后简化后结果

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
(function (modules) {
// webpackBootstrap
var installedModules = {};
// The require function
function __webpack_require__(moduleId) {
// Check if module is in cache
if (installedModules[moduleId]) {
return installedModules[moduleId].exports;
}
// Create a new module (and put it into the cache)
var module = (installedModules[moduleId] = {
i: moduleId,
l: false,
exports: {},
});
// Execute the module function
modules[moduleId].call(
module.exports,
module,
module.exports,
__webpack_require__
);
// Flag the module as loaded
module.l = true;
// Return the exports of the module
return module.exports;
}
})({
"./src/js/a.js": function (module, exports) {
console.log("a");
},

"./src/js/b.js": function (module, exports) {
console.log("b");
},

"./src/main.js": function (module, __webpack_exports__, __webpack_require__) {
__webpack_require__.r(__webpack_exports__);
var _js_a__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(
"./src/js/a.js"
);
var _js_b__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(
"./src/js/b.js"
);
},
});

附一份自己的webpack配置
传送门

您的支持将鼓励我继续创作!