webpack5

声明:所有的文章demo都在我的仓库里 webpack5

起步

概念

webpack是用于编译JavaScript模块。

一个文件依赖另一个文件,包括静态资源(图片/css等),都会视为依赖关系。

在webpack处理程序时,会在入口处,根据依赖关系进行处理,生成一个依赖关系图,最终将所有的文件打包成一个bundle。

当浏览器发起请求时,大大节约了时间。

更新方向

  1. 尝试用持久性缓存来提高构建性能。
  2. 尝试用更好的算法和默认值来改进长期缓存。
  3. 尝试用更好的 Tree Shaking 和代码生成来改善包大小。
  4. 尝试改善与网络平台的兼容性。
  5. 尝试在不引入任何破坏性变化的情况下,清理那些在实现 v4 功能时处于奇怪状态的内部结构。
  6. 试图通过现在引入突破性的变化来为未来的功能做准备,使其能够尽可能长时间地保持在 v5 版本上。

安装

创建文件夹并初始化,文件夹中会出现package.js文件,是基础的一些配置,包括文件名称/版本/描述/入口文件/关键字/作者等。

  1. npm init -y

安装webpackwebpack-cli工具,可以在终端运行webpack相关命令

node 8.2/npm 5.2.0提供npx命令,可以使用npx webpack去安装npx

根据相应的提示,安装webpack-cliwebpack

  1. npm install -D webpack-cli

我安装的版本如下:

  1. "devDependencies": {
  2. "webpack": "^5.1.0",
  3. "webpack-cli": "^4.0.0"
  4. },

打包

使用npx webpack进行打包,会在/dist文件夹中,生成mian.js文件,这个是对index.js文件以及相应依赖进行的打包文件

出现如下结果,表示打包成功

在浏览器中打开index.html,出现结果如下:

配置文件 webpack.config.js

在完成配置的webpack.config.js的文件夹后,再次打包,打包命令是npx webpack --config webpack.config.js

一般情况下,如果存在webpack.config.js文件,将默认选择根据这个配置文件进行打包,即npx webpack即可

其中--config表示根据什么文件配置进行打包,后面的参数就是对应的文件名称

配置文件里面都是一些配置,如loader/plugin/resolve

快捷方式

package.json文件中,配置script

  1. "scripts": {
  2. "test": "echo \"Error: no test specified\" && exit 1",
  3. "build":"webpack"
  4. },

可快速的通过npm run build进行打包,效果跟之前的npx webpack一致。

*** 以上代码在webpack-demo1

管理资源

由于webpack只能打包js文件,但是其他文件,如图片/css等,如何打包呢?

基本的思路都是将相应的资源都转化成js文件

css

正常的css文件例子如下

安装 style-loadercss-loader

  1. npm i --save-dev style-loader css-loader

webpack.config.js中配置相应的css,顺序很重要,'style-loader','css-loader'

最终打包出来的是一个js文件

  1. module:{
  2. rules:[{
  3. test:/\.css$/,
  4. use:['style-loader','css-loader']
  5. }]
  6. }

上图展示的是在head中添加了style,由此我猜测,style-loader的作用是将css文件放置到head中去渲染,css-loader的作用是将css文件(包含其他形式的css,如.scss)转化成js文件

其他的比如less/sass等,都跟css写法保持一致,最需将匹配的test,改成相对应的文件后缀。

image图片

安装解析文件的loader,npm i --save-dev file-loader

并在module中进行配置

  1. module:{
  2. rules:[{
  3. test:/\.(css|scss)$/,
  4. use:['style-loader','css-loader']
  5. },{
  6. test:/\.(png|jpeg|jpg|svg)$/,
  7. use:['file-loader']
  8. }]
  9. }

如上图所示,发现webpack以及将路径转义了。

其他形式的文件,都是以上面相应的方法进行安装和配置即可。

*** 以上代码在webpack-demo2

管理输出

当文件程序变得复杂,而且在entry中使用多个入口,并输出多个bundle,如果要手动在index.html中添加,便使得整个代码看起来不便捷

这时使用插件html-webpack-plugin

html-webpack-plugin

这个插件可以自动更新index.html中有关js引入的文件

安装npm i --save-dev html-webpack-plugin

使用:

  1. const HtmlWebpackPlugin=require('html-webpack-plugin')
  2. plugins:[
  3. new HtmlWebpackPlugin({
  4. title:'管理输出'
  5. })
  6. ]

缺点是不能去除之前的旧文件,这时引入clean-webpack-plugin

clean-webpack-plugin

这个插件可去除/dist文件

在构建前去除/dist文件,可以达到效果

安装npm i --save-dev clean-webpack-plugin

使用:

  1. const {CleanWebpackPlugin}=require('clean-webpack-plugin')
  2. plugins:[
  3. new CleanWebpackPlugin(),
  4. new HtmlWebpackPlugin({
  5. title:'管理输出'
  6. })
  7. ]

*** 以上代码在webpack-demo3

开发环境

这部分是在开发环境,切不可在生产环境使用。

配置环境

webpack.config.js中进行mode的配置

  1. mode:'development'

定位错误(source map)

打包文件时,由于打包到一个文件里,如果出现语法错误,只会定位到打包后的文件,对于我们查找问题就不太方便。

source map有很多的配置,对于我们现在打包定位错误,只需其中的devtool配置即可。

  1. devtool: 'inline-source-map',

如webpack-demo4中的例子所示,print.js中,刻意写错代码如:cnlll.log('This is output')

正常打包,在浏览器运行时,会在console里显示报错的文件,以及错误的原因。

自动编译

webpack-dev-server插件提供一个简单的web server,且具有热加载的功能。

安装npm i --save-dev webpack-dev-server

在配置文件中配置:

  1. devServer:{
  2. contentBase:'./dist'
  3. },

以上代码是告诉dev server,将dist文件下的文件,挂载到localhost:8080下。

package.json中进行配置口令运行 dev server

教程上建议如下配置

  1. "start": "webpack-dev-serve --open"

在实践操作中,在执行npm run start时,我出现以下报错

  1. > webpack-demo4@1.0.0 start /Users/alicezhao/Desktop/learn/demos/my-notes/tools/webpack/webpack5/webpack-demo4
  2. > webpack-dev-server --open
  3. internal/modules/cjs/loader.js:969
  4. throw err;
  5. ^
  6. Error: Cannot find module 'webpack-cli/bin/config-yargs'
  7. Require stack:
  8. - /Users/alicezhao/Desktop/learn/demos/my-notes/tools/webpack/webpack5/webpack-demo4/node_modules/webpack-dev-server/bin/webpack-dev-server.js
  9. at Function.Module._resolveFilename (internal/modules/cjs/loader.js:966:15)
  10. at Function.Module._load (internal/modules/cjs/loader.js:842:27)
  11. at Module.require (internal/modules/cjs/loader.js:1026:19)
  12. at require (internal/modules/cjs/helpers.js:72:18)
  13. at Object.<anonymous> (/Users/alicezhao/Desktop/learn/demos/my-notes/tools/webpack/webpack5/webpack-demo4/node_modules/webpack-dev-server/bin/webpack-dev-server.js:65:1)
  14. at Module._compile (internal/modules/cjs/loader.js:1138:30)
  15. at Object.Module._extensions..js (internal/modules/cjs/loader.js:1158:10)
  16. at Module.load (internal/modules/cjs/loader.js:986:32)
  17. at Function.Module._load (internal/modules/cjs/loader.js:879:14)
  18. at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:71:12) {
  19. code: 'MODULE_NOT_FOUND',
  20. requireStack: [
  21. '/Users/alicezhao/Desktop/learn/demos/my-notes/tools/webpack/webpack5/webpack-demo4/node_modules/webpack-dev-server/bin/webpack-dev-server.js'
  22. ]
  23. }
  24. npm ERR! code ELIFECYCLE
  25. npm ERR! errno 1
  26. npm ERR! webpack-demo4@1.0.0 start: `webpack-dev-server --open`
  27. npm ERR! Exit status 1
  28. npm ERR!
  29. npm ERR! Failed at the webpack-demo4@1.0.0 start script.
  30. npm ERR! This is probably not a problem with npm. There is likely additional logging output above.
  31. npm ERR! A complete log of this run can be found in:
  32. npm ERR! /Users/alicezhao/.npm/_logs/2020-10-15T07_50_22_972Z-debug.log

我的有关webpack版本配置如下

  1. "devDependencies": {
  2. "clean-webpack-plugin": "^3.0.0",
  3. "html-webpack-plugin": "^4.5.0",
  4. "webpack": "^5.1.0",
  5. "webpack-cli": "^4.0.0",
  6. "webpack-dev-server": "^3.11.0"
  7. },

我在github上找到相关的问题,看这里

webpack-dev-server版本不支持webpack5.0webpack-cli4.0

最终在package.json应做如下配置

  1. "start": "webpack serve --mode development --env development"

再执行npm run start就正常启动。

*** 以上代码在webpack-demo4

关注我,webpack5文档还有后续...

我的仓库地址,github,欢迎star~~

webpack5文档解析(上)的更多相关文章

  1. webpack5文档解析(下)

    声明:所有的文章demo都在我的仓库里 代码分离 代码分离的有点在于: 切割代码,生成不同的打包文件,按需加载这些文件. 每个bundle的体积更小 控制外部资源的加载顺序 常用的方法有: 入口起点: ...

  2. JavaScript : DOM文档解析详解

    JavaScript DOM  文档解析 1.节点(node):来源于网络理论,代表网络中的一个连接点.网络是由节点构成的集合 <p title=“a gentle reminder”> ...

  3. ios-XML文档解析之SAX解析

    首先SAX解析xml *xml文档的格式特点是节点,大体思路是把每个最小的子节点作为对象的属性,每个最小子节点的'父'节点作为对象,将节点转化为对象,输出. 每个节点都是成对存在的,有开始有结束.有始 ...

  4. Android XML文档解析(一)——SAX解析

    ---------------------------------------------------------------------------------------------------- ...

  5. iOS网络编程笔记——XML文档解析

    今天利用多余时间研究了一下XML文档解析,虽然现在移动端使用的数据格式基本为JSON格式,但是XML格式毕竟多年来一直在各种计算机语言之间使用,是一种老牌的经典的灵活的数据交换格式.所以我认为还是很有 ...

  6. “Word自动更改后的内容保存到通用文档模板上。是否加载该模板?“的解决办法

    在win7系统下,Word2010出现了不能正常关闭.打开一个已有word文档,点击右上角关闭按钮后,先提示"word已停止工作,windows正在检查该问题的解决方案",随后提示 ...

  7. jsoup -- xml文档解析

    jsoup -- xml文档解析 修改 https://jsoup.org/cookbook/modifying-data/set-attributes https://jsoup.org/cookb ...

  8. [转载]Java动态填充word文档并上传到服务器

    一. 需求背景 在一些特殊应用场合,客户希望在服务器上生成文档的同时并填充数据,客户端的页面不显示打开文档,但是服务器上生成文档对服务器压力很大,目前服务器上生成文档第一种就是方式是jacob, 但是 ...

  9. [原创]Java动态填充word文档并上传到服务器

    一. 需求背景 在一些特殊应用场合,客户希望在服务器上生成文档的同时并填充数据,客户端的页面不显示打开文档,但是服务器上生成文档对服务器压力很大,目前服务器上生成文档第一种就是方式是jacob, 但是 ...

随机推荐

  1. 使用dbUnit的 IDataSet 因乱序造成assert失败而采取的措施

    本例源码下载:https://files.cnblogs.com/files/xiandedanteng/dbUnitTest20200211.zip 在做IDataSet比较时,特殊情况下会有期盼的 ...

  2. Git 沙盒模拟实战(基础篇)

    Git 沙盒模拟实战 分支 现有一个主分支 创建分支 # 创建分支 $ git branch bugFix # 切换到指定分支 $ git checkout bugFix 或者 # 创建分支,并切换到 ...

  3. 别再眼高手低了! 这些Linq方法都清楚地掌握了吗?

    不要再眼高手低了,这些Enumerable之常见Linq扩展方法都清楚掌握了吗?其实这是对我自己来说的! 例如:一个人这个技术掌握了一点那个技术也懂一点,其他的好像也了解一些,感觉自己啥都会一点,又觉 ...

  4. centos 遇到/dev/mapper/cl-root 100% 解决方法

    yum安装docker时报错[Errno 2] No usable temporary directory found in ['/tmp', '/var/tmp', '/usr/tmp', '/'] ...

  5. [剑指Offer]65-不用加减乘除做加法

    题目 写一个函数,求两个整数之和,要求在函数体内不得使用+.-.*./四则运算符号. 题解 用位运算模拟加法的三步: 无进位加法:异或运算. 进位:与运算再左移一位. 直到进位为0结束. 代码 pub ...

  6. [HDOJ1232]畅通工程(并查集)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=1232 题目描述 Problem Description 某省调查城镇交通状况,得到现有城镇道路统计表, ...

  7. 软件开发过程中常用的环境解释DEV FAT UAT PRO

    1.DEV Development environment 开发环境,用于开发者调试使用 2.FAT Feature Acceptance Test environment 功能验收测试环境,用于软件 ...

  8. 小白的springboot之路(十八)、i18n多语言支持(后端篇)

    0-前言 在有些系统中,比如网站,往往需要支持多国语言,英文版中文版什么的,这个其实也不难: 今天我们就来介绍spring boot中用i18n在后端支持多语言: 当然,也可以直接在前端用i18n直接 ...

  9. P4742 【[Wind Festival]Running In The Sky】

    相信来做这道题的人肯定都学过\(Tarjan\)缩点吧,如果没有建议先去做P3387 [模板]缩点,如果你忘了,建议也去看看 满足上面要求后,你会惊奇发现,这两道题基本一样,唯一的差别就是这道题需要记 ...

  10. python常用os模块

    OS 模块 #os模块就是对操作系统进行操作,使用该模块必须先导入模块: import os #getcwd() 获取当前工作目录(当前工作目录默认都是当前文件所在的文件夹) result = os. ...