概述
在模块化编程中, 通常以“模块”为单位来编写应用程序,这种编程方式便于维护、测试和发现问题。在 web 端,模块化的支持姗姗来迟,许多模块化编程工具相继涌现,来解决模块化编程问题,webpack 便是其中一种工具。
通常,一个 module 模块就是指一个文件中导出的内容,webpack 会将这些 module 打包成一个或多个 chunk 。
Webpack Module
webpack 支持以下模块化语法:
- ES2015(ES6)import ;
- CommonJS require ;
- AMD define 和 require;
- css/sass/less @import ;
- stylesheet image url url() 和 <img src=…>;
ES6 import
index.js
import {
a,
b,
c
} from './module';
console.log(a, b, c);
module.js
const a = 1;
const b = 2;
const c = 3;
export {
a,
b,
c
};
webpack.config.js
var HtmlWebpackPlugin = require('html-webpack-plugin');
var {CleanWebpackPlugin} = require('clean-webpack-plugin');
module.exports = {
mode: 'development',
entry: {
index: './index.js',
},
output: {
publicPath: '',
path: __dirname + '/dist',
filename: '[name].[chunkhash:20].js'
},
module: {
rules: []
},
plugins: [
new CleanWebpackPlugin(),
new HtmlWebpackPlugin({template: './index.html'}),
]
}
打包后代码(片段)
"./index.js": (function (module, __webpack_exports__, __webpack_require__) {
"use strict";
eval(`__webpack_require__.r(__webpack_exports__);n
/* harmony import */
var _module1__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./module1 */ "./module1.js");nrn
console.log(
_module1__WEBPACK_IMPORTED_MODULE_0__["a"],
_module1__WEBPACK_IMPORTED_MODULE_0__["b"],
_module1__WEBPACK_IMPORTED_MODULE_0__["c"]
);nn
//# sourceURL=webpack:///./index.js?`);
}),
"./module1.js": (function (module, __webpack_exports__, __webpack_require__) {
"use strict";
eval(`
__webpack_require__.r(__webpack_exports__);n
/* harmony export (binding) */
__webpack_require__.d(__webpack_exports__, "a", function() { return a; });n
/* harmony export (binding) */
__webpack_require__.d(__webpack_exports__, "b", function() { return b; });n
/* harmony export (binding) */
__webpack_require__.d(__webpack_exports__, "c", function() { return c; });n
const a = 1;rn
const b = 2;rn
const c = 3;rnnn
//# sourceURL=webpack:///./module1.js?`);
})
CommonJS require
index.js
const {a, b, c} = require('./module');
console.log(a, b, c);
module.js
const a = 1;
const b = 2;
const c = 3;
module.exports = {
a,
b,
c
};
webpack.config.js
var HtmlWebpackPlugin = require('html-webpack-plugin');
var {CleanWebpackPlugin} = require('clean-webpack-plugin');
module.exports = {
mode: 'development',
entry: {
index: './index.js',
},
output: {
publicPath: '',
path: __dirname + '/dist',
filename: '[name].[chunkhash:20].js'
},
module: {
rules: []
},
plugins: [
new CleanWebpackPlugin(),
new HtmlWebpackPlugin({template: './index.html'}),
]
}
打包后代码(片段)
"./index.js": (function (module, exports, __webpack_require__) {
eval(`
const {a, b, c} = __webpack_require__(/*! ./module */ "./module.js");
console.log(a, b, c);
//# sourceURL=webpack:///./index.js?`);
}),
"./module.js": (function (module, exports) {
eval(`
const a = 1;
const b = 2;
const c = 3;
module.exports = {
a,
b,
c
};
//# sourceURL=webpack:///./module.js?`);
})
AMD define require
index.js
require(['./module'], function(module) {
console.log(module);
})
module.js
define({a: 1, b: 2, c: 3});
webpack.config.js
var HtmlWebpackPlugin = require('html-webpack-plugin');
var {CleanWebpackPlugin} = require('clean-webpack-plugin');
module.exports = {
mode: 'development',
entry: {
index: './index.js',
},
output: {
publicPath: '',
path: __dirname + '/dist',
filename: '[name].js',
chunkFilename:'[id].js'
},
module: {
rules: []
},
plugins: [
new CleanWebpackPlugin(),
new HtmlWebpackPlugin({template: './index.html'}),
]
}
amd 的代码打包后是懒加载模式的,使用 require 引入的代码会被打包成懒加载的 chunk ,它最终会被安装到主 chunk 中。
index.js
"./index.js": (function (module, exports, __webpack_require__) {
eval(`
__webpack_require__.e(/*! AMD require */ 0).then(function() {
/* WEBPACK VAR INJECTION */
(function(module) {
var __WEBPACK_AMD_REQUIRE_ARRAY__ = [__webpack_require__(/*! ./module */ "./module.js")];
(function(module) {
console.log(module);
}).apply(null, __WEBPACK_AMD_REQUIRE_ARRAY__);
/* WEBPACK VAR INJECTION */
}.call(
this,
__webpack_require__(/*! ./../../../../../../node/yarn/yarn_global/node_modules/webpack/buildin/module.js */
"../../../../../../node/yarn/yarn_global/node_modules/webpack/buildin/module.js"
)(module))
)}).catch(__webpack_require__.oe)
//# sourceURL=webpack:///./index.js?`);
})
module.js -> 0.js
(window["webpackJsonp"] = window["webpackJsonp"] || []).push([
[0], {
"../../../../../../node/yarn/yarn_global/node_modules/webpack/buildin/module.js": (function (module, exports) {
eval(`
module.exports = function(module) {
if (!module.webpackPolyfill) {
module.deprecate = function() {};
module.paths = [];
// module.parent = undefined by default
if (!module.children) module.children = [];
Object.defineProperty(module, "loaded", {
enumerable: true,
get: function() {
return module.l;
}
});
Object.defineProperty(module, "id", {
enumerable: true,
get: function() {
return module.i;
}
});
module.webpackPolyfill = 1;
}
return module;
};
//# sourceURL=webpack:///(webpack)/buildin/module.js?`);
}),
"./module.js": (function (module, exports, __webpack_require__) {
eval(`
!(module.exports = {a: 1, b: 2, c: 3});
//# sourceURL=webpack:///./module.js?`);
})
}
]);
打包后的代码只能在与浏览器相同的环境中跑,因为它要用到 window 和 DOM 等 。
css/sass/less @import
先安装 css-loader
yarn add css-loader -D
index.js
var cssModule = require('./index.css');
console.log(cssModule);
console.log(cssModule.toString());
console.log('index.js');
index.css
@import './module';
.index {
color: orange;
}
module.css
.module {
color:red;
}
webpack.config.js
var HtmlWebpackPlugin = require('html-webpack-plugin');
var {
CleanWebpackPlugin
} = require('clean-webpack-plugin');
module.exports = {
mode: 'development',
entry: {
index: './index.js',
},
output: {
publicPath: '',
path: __dirname + '/dist',
filename: '[name].[chunkhash:20].js'
},
module: {
rules: [{
test: /.css$/,
use: 'css-loader',
}]
},
plugins: [
new CleanWebpackPlugin(),
new HtmlWebpackPlugin({
template: './index.html'
}),
]
}
如果在 js 里引入 css , 那么 css 模块的代码也会被打包到 chunk 里,打包后片段代码如下(去掉了 eval )。
"./index.css": (function (module, __webpack_exports__, __webpack_require__) {
"use strict";
// 标记为 ES6 模块
__webpack_require__.r(__webpack_exports__);
/* harmony import */
// css-loader 提供的一个函数,用于处理 css module ,返回一个 list 数组,并将其作为 css module 的默认导出
var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__( /*! ./node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");
/* harmony import */
//这个函数返回的是 css-loader 生成的那个函数,即上面说的那个函数
var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/ __webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */
// 导入的 module.css 模块,exports['default'] 是 list 数组
var _node_modules_css_loader_dist_cjs_js_module_css__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__( /*! -!./node_modules/css-loader/dist/cjs.js!./module.css */ "./node_modules/css-loader/dist/cjs.js!./module.css");
// Imports
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_0___default()(function (i) {
return i[1]
});
// 安装 module.css 的 module , 将还未安装的 module.css 的 module 的 list 元素 push 到 index.css module 的 list 中
___CSS_LOADER_EXPORT___.i(_node_modules_css_loader_dist_cjs_js_module_css__WEBPACK_IMPORTED_MODULE_1__["default"]);
// Module
// list 数组 push index.css 的内容
___CSS_LOADER_EXPORT___.push([module.i, `.index {
color: orange;
}`, ""]);
// Exports
/* harmony default export */
// 导出 list 数组
__webpack_exports__["default"] = (___CSS_LOADER_EXPORT___);
//# sourceURL=webpack:///./index.css?`
}),
"./index.js": (function (module, exports, __webpack_require__) {
var cssModule = __webpack_require__( /*! ./index.css */ "./index.css");
console.log(cssModule);
console.log(cssModule.default.toString());
console.log('index.js');
}),
"./node_modules/css-loader/dist/cjs.js!./module.css": (function (module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__); /* harmony import */
var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__( /*! ./node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");
console.log(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_0__) // function a
/* harmony import */
var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/ __webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_0__);
console.log(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_0___default); // function return function a
// Imports
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_0___default()(function (i) { // cssWithMappingToString
return i[1]
});
// Module
console.log(module)
___CSS_LOADER_EXPORT___.push([module.i, `.module {
color:red;
}`, ""]);
// Exports
/* harmony default export */
__webpack_exports__["default"] = (___CSS_LOADER_EXPORT___);
//# sourceURL=webpack:///./module.css?./node_modules/css-loader/dist/cjs.js
}),
// 会导出 css-loader 提供的的一个函数
"./node_modules/css-loader/dist/runtime/api.js": (function (module, exports, __webpack_require__) {
"use strict";
module.exports = function (cssWithMappingToString) { // css-loader 提供的的一个函数
var list = []; // return the list of modules as css string
// 将 list 变成 css string , 如果有媒体查询,则为其添加媒体查询的 demo
list.toString = function toString() {
return this.map(function (item) {
var content = cssWithMappingToString(item); // item 是一个数组,取第1个元素
if (item[2]) { // 如果有第2个元素
return "@media ".concat(item[2], " {").concat(content, "}");
}
// 没有第2个元素,直接返回第1个元素
return content;
}).join("");
};
// import a list of modules into the list
// eslint-disable-next-line func-names
list.i = function (modules, mediaQuery, dedupe) {
if (typeof modules === "string") {
// eslint-disable-next-line no-param-reassign
modules = [
[null, modules, ""]
];
}
var alreadyImportedModules = {};
if (dedupe) {
for (var i = 0; i < this.length; i++) {
// eslint-disable-next-line prefer-destructuring
var id = this[i][0];
if (id != null) {
alreadyImportedModules[id] = true;
}
}
}
for (var _i = 0; _i < modules.length; _i++) {
var item = [].concat(modules[_i]);
if (dedupe && alreadyImportedModules[item[0]]) {
// eslint-disable-next-line no-continue
continue;
}
if (mediaQuery) {
if (!item[2]) {
item[2] = mediaQuery;
} else {
item[2] = "".concat(mediaQuery, " and ").concat(item[2]);
}
}
list.push(item);
}
};
return list;
};
//# sourceURL=webpack:///./node_modules/css-loader/dist/runtime/api.js?
})
执行打包后的代码,打印如下。
关于 sass 、 less 的处理方式还要引入对应的 loader ,后续的处理和上面的类似。
stylesheet url() 和 <img src=…>
先安装 url-loader
yarn add css-loader -D
在目录里新增一个 images 文件夹,并放置一张图片 xxx.png ,然后还是在上述代码的基础上改造,变更的代码如下。
index.css
@import './module';
.index {
color: orange;
background-image: url(./images/xxx.png);
}
webpack.config.js
var HtmlWebpackPlugin = require('html-webpack-plugin');
var {
CleanWebpackPlugin
} = require('clean-webpack-plugin');
module.exports = {
mode: 'development',
entry: {
index: './index.js',
},
output: {
publicPath: '',
path: __dirname + '/dist',
filename: '[name].[chunkhash:20].js'
},
module: {
rules: [{
test: /.css$/,
use: 'css-loader',
},{
test: /.png$/,
use: 'url-loader'
}]
},
plugins: [
new CleanWebpackPlugin(),
new HtmlWebpackPlugin({
template: './index.html'
}),
]
}
打包后的代码片段
"./images/xxx.png": (function (module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
__webpack_exports__["default"] = ("");
}),
"./index.css": (function (module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony import */
var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__( /*! ./node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");
/* harmony import */
var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/ __webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */
var _node_modules_css_loader_dist_cjs_js_module_css__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__( /*! -!./node_modules/css-loader/dist/cjs.js!./module.css */ "./node_modules/css-loader/dist/cjs.js!./module.css");
/* harmony import */
var _node_modules_css_loader_dist_runtime_getUrl_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__( /*! ./node_modules/css-loader/dist/runtime/getUrl.js */ "./node_modules/css-loader/dist/runtime/getUrl.js");
/* harmony import */
var _node_modules_css_loader_dist_runtime_getUrl_js__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/ __webpack_require__.n(_node_modules_css_loader_dist_runtime_getUrl_js__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */
var _images_xxx_png__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__( /*! ./images/xxx.png */ "./images/xxx.png");
// Imports
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_0___default()(function (i) {
return i[1]
});
___CSS_LOADER_EXPORT___.i(_node_modules_css_loader_dist_cjs_js_module_css__WEBPACK_IMPORTED_MODULE_1__["default"]);
var ___CSS_LOADER_URL_REPLACEMENT_0___ = _node_modules_css_loader_dist_runtime_getUrl_js__WEBPACK_IMPORTED_MODULE_2___default()(_images_xxx_png__WEBPACK_IMPORTED_MODULE_3__["default"]);
// Module
___CSS_LOADER_EXPORT___.push([module.i, `.index {
color: orange;
background-image: url( ${___CSS_LOADER_URL_REPLACEMENT_0___});
}`, ""]);
__webpack_exports__["default"] = (___CSS_LOADER_EXPORT___);
}),
控制台相关打印截图如下。
然后实践 html 中的 src 的处理,先装一下 html-loader 。
// 这里安装 v1 版本,其他版本安装执行后报错了...
yarn add html-loader@1 -D
webpack.config.js
var HtmlWebpackPlugin = require('html-webpack-plugin');
var {
CleanWebpackPlugin
} = require('clean-webpack-plugin');
module.exports = {
mode: 'development',
entry: {
index: './index.js',
},
output: {
publicPath: '',
path: __dirname + '/dist',
filename: '[name].[chunkhash:20].js'
},
module: {
rules: [{
test: /.png$/,
use: 'url-loader'
},{
test: /.html$/,
use:[{
loader:'html-loader'
}]
}]
},
plugins: [
new CleanWebpackPlugin(),
new HtmlWebpackPlugin({
template: './index.html'
}),
]
}
index.js
var htmlModule = require('./index.html');
console.log(htmlModule);
console.log('index.js');
index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<img src="./images/xxx.png" alt="">
</body>
</html>
这里就不看打包后的代码了,因为 html-loader 也是将 html 文件变成了一个 module ,最后打印如下。
因为这里的 index.html是作为了模板的,它应该也会被 html-loader 处理,所以再来看看打包生成的的 index.html 文件。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<img src="" alt="">
<script src="index.4ae18d04e0997fdb9c0a.js"></script></body>
</html>
支持的模块类型
- CoffeeScript
- TypeScript
- ESNext (Babel)
- Sass
- Less
- Stylus
只要提供对应的预处理器, webpack 就可以处理这些模块文件!
最后
以上就是灵巧音响为你收集整理的webpack4 文档(入门) - 第七章 - module的全部内容,希望文章能够帮你解决webpack4 文档(入门) - 第七章 - module所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复