进阶篇——webpack进阶用法(一)

  上一章节主要介绍了webpack的基础用法,这一章节我们进一步学习webpack的进阶用法,能够更加加深对webpack的理解,增强css解析、代码分割、代码打包、打包组件...

1.课程目录

TIM截图20200724094110.png

2.自动清理构建目录产物

(1)历史遗留问题

上一章节中我们在构建的时候,我们没有通过webpack自动的去清理构建目录,而是每次手动的去清理,显得很是浪费时间


微信截图_20200801202720.png
(2)解决方法
  1. 通过npm命令手动去清理,如下:


    微信截图_20200801202908.png

    注:这样显得代码不够优雅,每次构建之前都要手动输入以上命令,很是繁琐。有没有自动清理的方法呢?如下

  2. 安装clean-webpack-plugin
    微信截图_20200801203201.png

    安装
    npm i clean-webpack-plugin -D
    没使用该插件前
    微信截图_20200801210206.png

    我们可以发现,index.js和search.js每次构建时,都会重复生成文件,造成dist文件的内容过大。
    使用该插件后,如下
    微信截图_20200801213231.png

3.PostCSS插件autoprefixer自动补齐CSS3前缀

目前市面上有各种各样的浏览器,各大厂商对css的兼容处理也是不尽相同,因此为了使css的属性能够兼容各大浏览,出现了各种css前缀,目前主流的浏览器如下(包含css前缀)

微信截图_20200802153023.png

例子如下
微信截图_20200802153202.png

通过上面的例子我们可以看出,当我们编写css样的时候,需要手动不全前缀,这样做是非常浪费时间的,有没有我们在开发时正常编写css样式,在构建项目的时候,代码能够自动帮我们补全css样式的前缀呢?答案是有的,如下
微信截图_20200802153552.png

autoprfixer是css样式的后置处理器,与less-loader、sass-loader不同,它们是css的预处理器
预处理器:一般是在webpack打包前处理文件,如less-loader、sass-loader是在webpack打包css样式前,将less文件、sass文件通过预处理器转换css文件,再进行打包处理。
后置处理器:是webpack在将css打包后,再对文件处理,如autoprefixer是将打包好的css文件进行css样式前缀添加。
browsers: ["last 2 version", "> 1%", "iOS 7"]:含义是兼容到最近的2个版本且使用人数大于1%且最低版本是IOS7的浏览器。
使用autoprefixer之前,构建的结果如下
微信截图_20200802154933.png

可以看到display属性并没有补全。
接下来我们来看一下使用autoprfixer插件看一下
npm install postcss-loader autoprefixer -D
注:autoprefixer一般和postcss-loader一起配合使用
微信图片_20200802160815.png

可以看到,这个插件已经帮我们做了自动补齐

4.移动端CSS px自动装换成rem

我们知道现在市面上的移动端是百花齐放,各种分辨率都有,为了能够使前端项目能够兼容各个版本的浏览器,我们需要将px转换成rem。我们先来看一张以IOS为例浏览器分辨率的图,如下:


QQ截图20200806212514.png

那如何做浏览器的适配呢?

(1)第一种方法:媒体查询

QQ截图20200806212757.png

缺点:需要些多套适配样式代码,造成项目体积的冗余,运行速度过慢,在这里不推荐使用媒体查询。

(2)第二种方法:rem

css3出来之后,提出了一个rem单位,含义如下

QQ截图20200806214854.png

推荐使用该方法。使用方法如下
QQ截图20200806215037.png

npm install px2rem-loader -D
npm install lib-flexible -S
remUnit:rem相对于px的一个单位,这里75表示,1rem=75px;
remPrecision:表示px转换rem时,保留小数点的位数,这里的8表示保留小数点后8位。
结果如下
QQ截图20200806220331.png

5.静态资源内联

QQ截图20200809164104.png
(1)HTML、JS内联
QQ截图20200809171113.png

注:使用raw-loader内联JS时,可能js代码里面会有ES6语法,这时候就要先用babel-loader进行代码转换,再使用raw-loader内联js

(2)CSS内联

我们在讲css文件指纹的时候,使用MiniCssExtractPlugin(不能和style-loader一起使用)将css样式代码提取了出来,并且给css文件添加了指纹策略。现在我们来说另外两种方法。如下

QQ截图20200809174724.png

npm install raw-loader@0.5.1 -D

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