摘要:Webpack是一种前端资源构建工具,一个静态模块打包器。

1. 摘要

Webpack是一种前端资源构建工具,一个静态模块打包器。在Webpack看来,前端的所有资源文件(js/json/css/img/less/…)都会作为模块处理,当Webpack处理应用程序时,它将根据模块的依赖关系进行静态分析,打包生成对应的静态资源。Webpack打包流程图如图1-1所示。

图1-1 Webpack打包流程图

2. Webpack五个核心概念

2.1 Entry

入口(Entry)指示Webpack以哪个文件作为入口起点分析构建内部依赖图并进行打包。

2.2 Output

输出(Output)指示Webpack打包后的资源bundles输出到哪里去,以及如何命名。

2.3 Loader

Loader让Webpack能够去处理那些非JavaScript语言的文件,Webpack本身只能理解JavaScript。

2.4 Plugins

插件(Plugins)可以用于执行范围更广的任务,插件的范围包括从打包和压缩,一直到重新定义环境中的变量等。

2.5 Mode

模式(Mode)指示Webpack使用相应模式的配置。分为development和production两种模式,下面分别进行简述。

  • development: 开发模式,能让代码本地运行的环境,会将process.env.NODE_ENV的值设为development,同时启用NamedChunksPlugin和NamedModulesPlugin插件;
  • production: 生产模式,能让代码优化运行的环境,会将process.env.NODE_ENV的值设为production,同时启用FlagDependencyUsagePlugin、FlagIncludedChunksPlugin、ModuleConcatenationPlugin、NoEmitreplaceStringsPlugin、OccurrenceOrderPlugin、SideEffectsFlagPlugin和UglifyJsPlugin插件。

3. Wbepack配置

3.1 webpack.config.js文件

webpack.config.js是webpack的配置文件,用来指示webpack工作,运行webpack指令时,会加载里面的配置,所有构建工具都是基于nodejs平台运行的,默认采用commonjs模块化。webpack.config.js基础配置如图3-1所示。

图3-1 webpack.config.js基础配置

3.2 devServer配置

开发服务器(devServer)用来实现自动化(自动编译、自动打开浏览器、自动刷新浏览器),只会在内存中编译打包,不会有任何文件输出,本地安装webpack-dev-server后,通过npx webpack-dev-server命令启动devServer,核心代码如图3-2所示。

图3-2 devServer配置核心代码

3.3 打包html/样式/图片/其它资源

打包不同的资源会使用不同的loader和插件,打包html/样式/图片/其它资源的流程如下所述。

3.3.1 打包html资源

1.下载html-webpack-plugin插件;

2.引入html-webpack-plugin插件;

3.使用html-webpack-plugin插件,并进行相应配置。

3.3.2 打包样式资源

不同的样式文件需要配置不同的loader

1.下载loader;

2.配置loader,css样式文件使用css-loader和style-loader,less文件使用less-loader、css-loader和style-loader。其中css-loader的作用是将css文件变成commonjs模块加载到js文件中,style-loader的作用是创建style标签,将js中的样式资源插入进去,添加到head中生效。

3.3.3 打包图片资源

1.下载url-loader,file-loader

2.配置loader

3.3.4 打包其它资源

1.下载file-loader

2. 配置loader,配置该loader作用于不为html/css/less/js的其他文件

3.4 提取css成单独文件/css兼容性处理/压缩css

3.4.1 提取css成单独文件

样式文件打包后会默认和js文件一起输出,可以通过插件将打包后的css文件单独输出,流程如下所述。

1.下载mini-css-extract-plugin插件

2.引用该插件

3.配置

3.4.2 css兼容性处理

1.下载postcss-loader和postcss-preset-env

2.在package.json中browsetslist属性中分别对开发环境和生产环境进行兼容性配置,设置支持样式的浏览器版本

3.通过postcss找到package.json中browserslist里面的配置,通过配置加载指定的css兼容性样式。

3.4.3 压缩css

1.下载optimize-css-assets-webpack-plugin插件

2.引用该插件

3.使用该插件

3.5 js语法检查eslint/js兼容性处理/js压缩

3.5.1 js语法检查eslint

1.下载eslint-loader和eslint

2.在package.json中的eslintConfig中进行配置

3.配置eslint-loader,其中只需检测js文件并要排除第三方库,只检测自己写的源代码,同时可在options配置中设置fix:true,自动修复eslint的错误。

3.5.2 js兼容性处理

1.下载babel-loader、@babel/core、@babel/preset-env,通过@babel/preset-env做基本的js兼容性处理,然后通过corejs做前面无法实现的兼容性处理,并实现按需加载

2. 配置loader

js兼容性处理核心代码如图3-3所示

图3-3 js兼容性处理核心代码

3.5.3 js压缩

mode设置为production生产环境时会自动压缩js代码。

4. webpack性能优化

可以从开发环境和生产环境分别对webpack进行性能优化。其中开发环境主要考虑从打包构建速度和代码调试两个方面进行优化,生产环境主要考虑从打包构建速度和代码运行性能这两个方面进行优化。下面简单介绍下开发环境上通过HMR提升构建速度。

4.1 HMR

HMR(热模块替换),作用是一个模块发生变化后,只会更新打包这一个模块而不是所有模块,通过在devServer中设置hot:true属性启动HMR功能。

其中对于样式文件,可以使用HMR功能,因为style-loader内部实现了;

对于js文件,默认不能使用HMR功能,解决方法:修改入口文件js代码,添加支持HMR功能的代码,另外HMR只能处理非入口js文件的其他文件,对入口文件并不能生效,因为一旦入口文件更新,入口文件引入的其他文件一定会被重新加载;

对于html文件,默认不能使用HMR功能,同时会导致html文件不能热更新,解决方法:修改entry入口文件,将html文件引入,只能解决html文件不能热更新的问题。

js文件支持HMR功能的核心代码如图4-1所示。

图4-1 js文件支持HMR功能核心代码

4.2 HMR效果

在入口index.js文件中引入print.js文件,运行npx webpack-devserver后,页面如图4-2所示。

4-2 初始页面

修改print.js文件后,只会重新加载print.js文件,而不会重新加载index.js文件,HMR效果如图4-3所示。

4-3 HMR效果图

点击关注,第一时间了解华为云新鲜技术~

想了解Webpack,看这篇就够了相关推荐

  1. 想了解线性编辑与非线性编辑,看这篇就够了

    想了解线性编辑与非线性编辑,看这篇就够了 一.什么是线性编辑,线性编辑的概念及含义是什么? 答: 线性编辑的概念:线性编辑是一种磁带的编辑方式,它利用电子手段,根据节目内容的要求将素材连接成新的连续画 ...

  2. React入门看这篇就够了

    2019独角兽企业重金招聘Python工程师标准>>> 摘要: 很多值得了解的细节. 原文:React入门看这篇就够了 作者:Random Fundebug经授权转载,版权归原作者所 ...

  3. 一文详解JavaBean 看这篇就够了

    一文详解JavaBean 看这篇就够了 JavaBean的历史渊源 JavaBean的定义(通俗版) JavaBean应用 < jsp:useBean > < jsp:getProp ...

  4. uiautomation遍历windows所有窗口_万字长文!滑动窗口看这篇就够了!

    大家好,我是小浩.今天是小浩算法 "365刷题计划" 滑动窗口系列 - 整合篇.之前给大家讲解过一些滑动窗口的题目,但未作系统整理. 所以我就出了这个整合合集,整合工作中除了保留原 ...

  5. .NET Core实战项目之CMS 第五章 入门篇-Dapper的快速入门看这篇就够了

    写在前面 上篇文章我们讲了如在在实际项目开发中使用Git来进行代码的版本控制,当然介绍的都是比较常用的功能.今天我再带着大家一起熟悉下一个ORM框架Dapper,实例代码的演示编写完成后我会通过Git ...

  6. .NET Core实战项目之CMS 第二章 入门篇-快速入门ASP.NET Core看这篇就够了

    本来这篇只是想简单介绍下ASP.NET Core MVC项目的(毕竟要照顾到很多新手朋友),但是转念一想不如来点猛的(考虑到急性子的朋友),让你通过本文的学习就能快速的入门ASP.NET Core.既 ...

  7. [译]ASP.NET Core Web API 中使用Oracle数据库和Dapper看这篇就够了

    园子里关于ASP.NET Core Web API的教程很多,但大多都是使用EF+Mysql或者EF+MSSQL的文章.甚至关于ASP.NET Core Web API中使用Dapper+Mysql组 ...

  8. ASP.NET Core WebApi使用Swagger生成api说明文档看这篇就够了

    引言 在使用asp.net core 进行api开发完成后,书写api说明文档对于程序员来说想必是件很痛苦的事情吧,但文档又必须写,而且文档的格式如果没有具体要求的话,最终完成的文档则完全取决于开发者 ...

  9. Spring Cloud入门,看这篇就够了!

    点击▲关注 "中生代技术"   给公众号标星置顶 更多精彩 第一时间直达 概述 首先我给大家看一张图,如果大家对这张图有些地方不太理解的话,我希望你们看完我这篇文章会恍然大悟. 什 ...

  10. 面试率 90% 的JS事件循环Event Loop,看这篇就够了!! !

    面试率 90% 的JS事件循环Event Loop,看这篇就够了!! ! 事件循环(Event Loop)大家应该并不陌生,它是前端极其重要的基础知识.在平时的讨论或者面试中也是一个非常高频的话题. ...

最新文章

  1. 实战:基于tensorflow 的中文语音识别模型 | CSDN博文精选
  2. Android HAL模块的加载过程
  3. [正能量系列]赋闲的程序员(三)
  4. binlog2sql使用总结
  5. 百度AI 17篇 CVPR 2019 论文介绍(附下载)
  6. ORB-SLAM2初步(跟踪模块)
  7. 赋能金融全链路,360金融的融合中台究竟有何不同?
  8. package.json作用
  9. JAVA B/S系统实现客户端屏幕截图,Java版的QQ截图
  10. 进化计算中基于分类的预处理代理模型
  11. • 服务注册与发现(Eureka、Consul)
  12. SpreadJS 14.1 Crack by Xacker
  13. Window10系统下通过SMB协议连接和断开资源服务器
  14. EasyTalking微博系统
  15. ppi 各代iphone_各代iPhone逻辑分辨率与物理分辨率
  16. 【BZOJ2827】千山鸟飞绝 hash+堆+SBT
  17. pygame: libpng warning: iCCP: known incorrect sRGB profile 报错
  18. mysql 2203_mysql 错误2203 1061 及安装最后出现1067错误的解决办法
  19. 【雕爷学编程】Arduino动手做(2)---光敏电阻模块
  20. 高德地图实时定位显示图标和名字

热门文章

  1. 视觉SLAM笔记(26) 状态估计问题
  2. 深度学习笔记(30) Inception网络
  3. 北京理工大学计算机学院研究生培养方案,北京理工大学2018版学术型研究生培养方案.PDF...
  4. 怎样使用计算机网络,教大家怎样用电脑发出wifi信号,让手机共享!
  5. html td中加label,html – td对齐内的2个标签
  6. ajax同步获得数据字典的值,使用ajax加载数据字典,生成select(示例代码)
  7. typedef 及其与struct的结合使用
  8. 视频编码技术---压缩感知编码---匹配跟踪算法
  9. 手把手教你学node之搭建node.js开发环境
  10. [转]DES加密 java与.net可以相互加密解密两种方法