首页 > web前端 > css教程 > 正文

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

yulia
发布: 2018-09-12 16:56:32
原创
6217人浏览过

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

什么是盒子模型

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

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

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

立即学习前端免费学习笔记(深入)”;

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

cc1.jpg

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

盒子模型的作用

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

<style>
  .box {
    width: 200px;
    height: 100px;
    padding: 20px;
  }
</style>
<div class="box">
  盒子模型
</div>
登录后复制

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

cc2.jpg

这是为什么呢?因为默认情况下,设置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

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

*,
*:before,
*:after { 
  box-sizing: border-box;
}
登录后复制

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

html {
  box-sizing: border-box;
}

*,
*::before,
*::after {
  box-sizing: inherit;
}
登录后复制

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

以上就是深入理解CSS盒子模型含义和原理的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
相关标签:
css
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号