page contents

深入理解CSS盒子模型的含义和原理

本文讲述了简述你对css盒子模型的理解!具有很好的参考价值,希望对大家有所帮助。一起跟随六星小编过来看看吧,具体如下:

attachments-2022-03-gM1yb2nj62201c1056ed3.png

很多前端人员认为CSS太简单了,没必要花那么长的时间学习,其实不然,一个前端开发人员把CSS用好以后,效率和用户体验都会提升不少,最近打算深入的学习一下CSS,以便遇到问题时,才知道如何下手,从而迅速的对症下药。接下来主要介绍CSS的盒子模型。

什么是盒子模型

说起盒子模型,作为前端开发的我们,相信大家都有了解过的 。这里套用mdn官网的解释:

在一个文档中,每个元素都被表示为一个矩形的盒子。确定这些盒子的尺寸, 属性 --- 像它的颜色,背景,边框方面 --- 和位置是渲染引擎的目标。

在CSS中,使用标准盒模型描述这些矩形盒子中的每一个。这个模型描述了元素所占空间的内容。每个盒子有四个边:外边距边, 边框边, 内填充边与内容边。

官方语言总是那么的晦涩难懂,那我接用chrome的控制台的截图来说明吧:

attachments-2022-03-WNrhMxSU62201ae3a4c90.png

最外面橙色的就是外边距区域(margin area ),往里黄色的是边框区域(border area),再往里的绿色的是内边距区域(padding area ),最里面绿色的就是内容区域(content area)了。

盒子模型的作用

好吧,盒子模型的概念好像没有什么好说的,就上面那张图片罢了。下面一起来看看盒子模型对我们布局有什么影响。举个栗子,假如想设置一个元素的大小为200px,如果写了如下的代码:

  1. <style>
  2. .box {
  3. width: 200px;
  4. height: 100px;
  5. padding: 20px;
  6. }
  7. </style>
  8. <div class="box">
  9. 盒子模型
  10. </div>

结果,你在审查元素时,发现这个元素的大小变成了240px,而不是200px了。

attachments-2022-03-sABh0Xj862201afd636fc.png

这是为什么呢?因为默认情况下,设置width 、height 等作用对象是内容区域,所以设置的width: 200px仅仅是内容区域的宽度,加上左右内边距大小,导致了元素的整体尺寸变大了。这和我们对现实世界的中盒子的认识有差异的。比如,你我们说房子的面积,并不单单指可用面积,还要包括墙壁厚度、阳台、电梯之类的空间的。

盒子模型和box-sizing

为了把CSS和现实世界对应起来,这时候box-sizing就要用上场了。box-sizing是用来设置width、height的作用对象的。有三个值,分别是content-box 、 paading-box 、 border-box, 默认值是content-box。可能有人会问,为什么没有margin-box啊?具体原因就不知道了,可以参考张鑫旭老师在《CSS世界》一书中提到了两个原因:

margin-box 本身没有多大的价值

和 margin 的规范会冲突。因为margin规范写着“ margin的背景永远是透明的 ”,如果来个margin-box,那background怎么办?

至于为什么没有margin-box就简单的提一下,有兴趣的朋友可以自己去查一下。

最佳实践

为了布局上的方便,一些专家建议我们将所有的元素都设置为box-sizing: border-box

如果不考虑低版本浏览器的话,可以用下面的代码:

  1. *,
  2. *:before,
  3. *:after {
  4. box-sizing: border-box;
  5. }

后来,又有专家建议用的继承的方法,如下:

  1. html {
  2. box-sizing: border-box;
  3. }
  4. *,
  5. *::before,
  6. *::after {
  7. box-sizing: inherit;
  8. }

这种方法被称为最佳实践,具体原因就不说了,既然是专家推荐 ,那我们以后可以把第二种方法的段代码放到reset.css里面的。

更多相关技术内容咨询欢迎前往并持续关注六星社区了解详情。

如果你想用Python开辟副业赚钱,但不熟悉爬虫与反爬虫技术,没有接单途径,也缺乏兼职经验
关注下方微信公众号:Python编程学习圈,获取价值999元全套Python入门到进阶的学习资料以及教程,还有Python技术交流群一起交流学习哦。

attachments-2022-06-3lyv39G962b2d4e9e5204.jpeg

你可能感兴趣的文章

相关问题

0 条评论

请先 登录 后评论
轩辕小不懂
轩辕小不懂

2403 篇文章

作家榜 »

  1. 轩辕小不懂 2403 文章
  2. 小柒 1300 文章
  3. Pack 1135 文章
  4. Nen 576 文章
  5. 王昭君 209 文章
  6. 文双 71 文章
  7. 小威 64 文章
  8. Cara 36 文章