webpack从入门到精通(高级篇)

1.提升开发体验

SourceMap技术

作用:准确找到报错位置,便于开发

用法:

开发模式:cheap-module-source-map

优点:打包编译速度快,只包含行映射

缺点:没有列映射

生产模式:source-map

优点:包含行/列映射

缺点:打包编译速度更慢

2.提升打包构建速度

HMR:热更新,只更新编译的部分而不是刷新整个界面,想要实现js页面需要单独配置或者引入所需loader

oneOf:每个文件只能被其中一个loader配置处理

Include/Exclude

Include:只处理XXX文件

Exclude:处理XXX文件以外其他文件都处理

注意:只能用一种。两个同时用会报错

Cache

对eslint检查和Babel编译结果进行缓存

Thead

多进程打包:开启电脑的多个进程干一件事,速度更快

使用:

1.获取CUP的核数

2.下载包

npm i thread-loader -D

3.配置

获取cpu核数
eslint配置开启

3.减少代码体积

Tree Shaking

移除js中没有使用上的代码

Babel

@babel/plugin-transform-runtime:禁用Babel自动对每个文件的runtime注入,而是引入

1.下载包

npm i @babel/plugin-transform-runtime -D

2.配置

Image Minimizer

是什么:

image-minimizer-webpack-plugin:用来压缩图片的插件

用法:

1.下载包

npm i image-minimizer-webpack-plugin imagemin -D

无损压缩:

npm i imagemin-gifsicle imagemin-jpegtran imagemin-optipng imagemin-svgo -D 

有损压缩:

npm i imagemin-gifsicle imagemin-mozjpeg imagemin-pngquant imagemin-svgo -D 

2.配置

4优化代码运行性能

codeSplit

是什么:

代码分割:将打包生成的文件进行分割,生成多个js文件

按需加载:需要哪个文件就加载那个文件


Preload/Prefetch

在浏览器空闲时加载后续需要使用的资源

preload:告诉浏览器立即加载资源。

prefetch:告诉浏览器在空闲时才开始加载资源

共同点:

都会加载资源但不执行

都有缓存

区别:

preload优先级高,prefetch优先级低

preload只能加载当前页面所需要使用的资源,prefetch可以加载当前页面资源,也可以加载下一个页面需要使用的资源

总结:

当前页面优先级高的资源用preload加载

下一页面需要使用的资源用preload加载

怎么用:

1.下载包

npm i --save-dev @vue/preload-webpack-plugin

2.引入

3.配置

core-js

处理ES6及以上API的polyfill

polyfill翻译过来叫垫片/补丁。让我们在不兼容某些新特性的浏览器上,使用该新特性

怎么用

1.下载包

npm i core-js

2.引入

全局引入不需要的因会被引入 体积太大,手动引入太麻烦所以用以下这种方式

在babel中配置

PWA

项目在离线时应用程序能够继续运行功能

怎么用

1.下载包

npm i workbox-webpack-plugin --save-dev

2.配置

在main.js文件配置
在config中配置
在config中配置

总结

从4个角度对webpack和代码进行优化

1.提升开发体验

使用Source Map让开发上线时代码报错能力更加准确的错误提示

2.提升webpack打包构建速度

使用HotModuleReplacement让开发时之重新编译打包更新变化了的代码,不变的代码使用缓存,从而使更新速度更快

使用Oneof让资源一旦被某个loader处理就不继续遍历了,打包速度更快

使用Include/Exclude排除或只检测某些文件,处理的文件更少,速度更快

使用Cache对eslint和babel处理的结果进行缓存,第二次打包速度更快

使用Thead多进程处理eslint和babel任务,速度更快。

3.减少代码体积

使用Tree Shaking剔除了没有使用的多于代码,让代码体积更小

使用@babel/plugin-transform-runtime插件对babel进行处理,让辅助代码从中引入,而不是每个文件都生成辅助代码,从而体积更小

使用Image Minimizer对项目中图片进行压缩,体积更小请求速度更快

4.优化代码运行性能

使用Code Split对代码进行分割成多个js文件,从而使单个文件体积更小,并行加载js速度更快。并通过import动态导入语法进行按需加载,从而达到需要时才加载该资源,不用时不加载资源

使用Preload/Prefetch对代码进行提前加载,等未来需要使用时直接使用,让用户体验更好

使用Network Cache能对输出资源文件进行更好的命名,将来好做缓存

使用core-js 对js进行兼容处理

使用PWA让项目在离线状态下也能访问

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,830评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,992评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,875评论 0 331
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,837评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,734评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,091评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,550评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,217评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,368评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,298评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,350评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,027评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,623评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,706评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,940评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,349评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,936评论 2 341

推荐阅读更多精彩内容