面试官:聊一聊css-loader吧

前言

如果面试官这么问你,是想了解些什么?如果是你来回答,你会从哪些方面开始聊呢?首先这是一个很细节的问题对吧,你如果想要有的聊是不是得了解webpack,然后了解loader与plugin的区别,是不是还需要知道它是干什么的?以及如果我想用它还可能会用到其他的依赖吗?css的工程化是不是也得了解?

掌握一个东西的过程我喜欢的是先宏观,再微观,再到宏观。什么意思的呢?就是说某个技术大的流程是什么样的,然后掌握应用中解决什么问题需用到细节的点,最后你还可以从这些点再延伸回来,最后还可以和别人讲明白。我觉得这才是一个coder应该做的事。

css工程化

先写一段css:

问题来了,我想在我的webpack工程里引入这个样式文件,webpack能不能打包?看过我前几期文章的同学现在肯定可以异口同声的答出:不可以!你已经进步了你知道吗?

既然webpack处理不了css文件,那是不是要借助我们的扩展了,所以引出了css-loader(它干的活就是把css转换成字符串给webpack处理)

入口文件把刚写的热乎的样式文件引入:

配置一下css-loader(因为我一会儿还要在样式文件里加入背景图片,之前用到的处理图片的loader就先放在下面)

打包去浏览器控制台瞅一眼:

nice,小小的成功了一下,但是:

我页面引用了我写的样式为啥不生效?不生效就对了,哪来的样式?自然而然就引出了style-loader(它干的活就是把样式给你加载到你html的head里): 按照loader的执行顺序从右往左的顺序配置一下我们新加的依赖哈:

重新打包走起,看看页面:

你又成功啦,样式文件里我再加个背景图瞧瞧:

不出意外的话就要出意外了,为啥背景图片404了?

经过搜索,是因为css-loader和file-loader的模块化方式冲突导致的,改下配置:

重新打包,成功:

尾声

虽然我分享的这些点,可能在你的实际工作中需要自己来修改或者引入的机会并不多,但是我觉得你有必要了解清楚,需要在你的大脑里有一个清晰地方案,你要知道的你的项目是怎么跑起来的,而不是说因为我记住了要这样写就可以运行了而草草结尾。

相关推荐
Crystal32822 分钟前
background属性经典应用(视觉差效果/绘制纸张/绘制棋盘)
前端·css
洛卡卡了28 分钟前
一次上线事故,我干脆写了套灰度发布系统
后端·面试·架构
有点笨的蛋32 分钟前
彻底读懂移动端视口模型:<meta viewport> 的标准机制、历史遗留与工程真相
前端·html
前端开发爱好者44 分钟前
“最新国产代码大杀器”——MiniMax-M2!
前端·javascript
小马哥编程1 小时前
【软考架构】案例分析-web应用设计:SSH 和 SSM(Spring + Spring MVC + MyBatis ) 之间的区别,以及使用场景
前端·架构·ssh
用户103113311661 小时前
Vuex学习记录
前端
前端开发爱好者1 小时前
Electron 淘汰!新的跨端框架来了!性能飙升!
前端·javascript
狮子座的男孩1 小时前
js基础:08、构造函数(共享方法)、原型(prototype)、原型对象、(修改原型)toString方法、垃圾回收
前端·javascript·经验分享·prototype·垃圾回收·构造函数·原型对象
前端开发爱好者1 小时前
Vue 团队成员又搞了个 "新玩具"!
前端·javascript·vue.js
123461612 小时前
互联网大厂Java面试:从Spring Boot到微服务的探索
java·数据库·spring boot·微服务·面试·mybatis·orm