本质上,webpack 是一个现代 javascript 应用程序的静态模块打包器(module bundler)。当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个 bundle。
这是官网对webpack的解释。提到模块,模块顾名思义是独立的js文件。与之相近的词模块化,通俗地讲就是我们平时组织和管理代码方法的一种实现。
我们先来测试一下webpack的打包。
创建项目目录
mkdir webpackmini
2.安装webpack依赖
yarn add webpack -d
or
npm install webpack -d
3.安装webpack-cli依赖 这里,稍微注意一下,我们可以下载这个版本的,最新版的安装之后好像不可用。
yarn add webpack-cli@3.3.12 -d
or
npm install webpack@3.3.12 -d
1.创建项目主目录
mkdir src
2.创建入口文件
touch ma方法论有哪些in.js
3.编辑入口文件
我们这里使用最简单的一行代码。
console.log('maomin1');
在项目根目录下键入命令:
touch webpack.config.js
并编辑。
const path = require('path'); module.exports = { mode:'development', entry:'./src/main.js', output:{ path:path.resolve(__dirname,'dist'), filename:'bundle.min.js' }}
我们这里使用 npx webpack 命令进行打包。打包成功!
我们来到打包好的bundle.min.js文件,会看到以下代码:
/* * attention: the "eval" devtool has been ud (maybe by default in mode: "development"). * this devtool is neither made 住宿生for production nor for readable output files. * it us "eval()" calls to create a parate source file in the browr devtools. * if you are trying to read the output file, lect a different devtool (https://webpack.js.org/configuration/devtool/)* or disable the default devtool with "devtool: fal".* if you are looking for production-ready output files, e mode: "production" (https://webpack.js.org/configuration/mode/). */ /******/ (() => { // webpackbootstrap /******/ var __webpack_modules__ = ({ /***/ "./src/main.js": /*!*********************!* !*** ./src/main.js ***! *********************/ /***/ (() => { eval("console.log('maomin1');nn//# sourceurl=webpack://webpackmini/./src/main.js?"); /***/ }) /******/ }); /*******吴淼*****************************************************************/ /******/ /******/ // startup /******/ // load entry module and return exports /******/ // this entry module can't be inlined becau the eval devtool is ud. /******/ var __webpack_exports__ = {}; /******/ __webpack_modules__["./src/main.js"](); /******/ /******/ })() ;
我们将注释删掉后,会精简不少!
(() => { var __webpack_modules__ = ({ "./src/main.js": (() => {eval("console.log('maomin1');nn//# sourceurl=webpack://webpackmini/./情人节来源src/main.js?");}) }); var __webpack_exports__ = {}; __webpack_modules__["./src/main.js"]();})();
开始实战实现一个基础版的webpack。
1.首先我们在项目根目录下创建一个文件夹。
mkdir maominpack
2.然后,在maominpack文件夹下创建一个bin文件夹
mkdir bin
3.最后在bin文件夹下创建一个maominpack.js文件
编辑如下:
#!/usr/bin/env nodeconst fs = require('fs'); const ejs = require('ejs');const config = require('../../webpack.config.js');const entry = config.entry;const output = `${config.output.path}/${config.output.filename}`;const content = fs.readfilesync(entry,'utf8');let template = ` (() => { var __webpack_modules__ = ({ "<%-entry%>": (() => { eval("<%-content%>"); }) }); var __webpack_exports__ = {}; __webpack_modules__["<%-entry%>"](); })() ; `let package = ejs.render(template,{ entry, content}); fs.writefilesync(output,package);
首先,我们在头部指定环境为node环境,并且引入fs模块。然后,我们引入了ejs依赖,如果不是很了解ejs的,可以去官网浏览下。这里就简单的介绍一下。
“e” 代表什么?可以表示 “可嵌入(embedded)”,也可以是“高效(effective)”、“优雅(elegant)”或者是“简单(easy)”。ejs 是一套简单的模板语言,帮你利用普通的 javascript 代码生成 html 页面。ejs 没有如何组织内容的教条;也没有再造一套迭代新春致辞和控制流语法;有的只是普通的 javascript 代码而已。我们看到在将带有绑定值的字符串赋值给template变量,我们这里使用的ejs.render(),第一个参数是需要处理的字符串,第二个参数使我们需要修改的值,是一个对象。
4.在package.json文件下编辑如下:
{ "name": "maominpack", "version": "1.0.0", "bin":{ "maominpack":"bin/maominpack.js" }, "main": "index.js", "licen": "mit" }
5.为其命令创建快捷方式
npm link
6.为其配置在其他目录也可使用此命令
npm config ls
7.验证打包
我们将src/main.js修改一下。
console.log('maomin2');
然后,键入命令:
maominpack
最后,检查一下bundle.min.js:
(() => { var __webpack_modules__ = ({ "./src/main.js": (() => { eval("console.log('maomin2');"); }) }); var __webpack_exports__ = {}; __webpack_modules__["./src/main.js"]();})() ;
发现,我们打包成功了。这里我们只是实现了最基础的字符串替换打包功能,webpack还有很多值得玩的特性。
本文发布于:2023-04-05 15:36:13,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/721963f1c1d4a4d37709a05532d914b4.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:webpack入门教程(webpack入门知识详细介绍).doc
本文 PDF 下载地址:webpack入门教程(webpack入门知识详细介绍).pdf
留言与评论(共有 0 条评论) |