盒子模型是html+css中最核心的基础知识,理解了这个重要的概念才能更好的排版,进行页面布局。下面是自己积累和总结的关于css盒子模型的知识^_^,希望对初学者有用。

一、css盒子模型概念

CSS css盒子模型 又称框模型 (Box Model) ,包含了元素内容(content)、内边距(padding)、边框(border)、外边距(margin)几个要素。如图:

图中最内部的框是元素的实际内容,也就是元素框,紧挨着元素框外部的是内边距padding,其次是边框(border),然后最外层是外边距(margin),整个构成了框模型。通常我们设置的背景显示区域,就是内容、内边距、边框这一块范围。而外边距margin是透明的,不会遮挡周边的其他元素。

那么,元素框的总宽度 = 元素(element)的width + padding的左边距和右边距的值 + margin的左边距和右边距的值 + border的左右宽度;

元素框的总高度 = 元素(element)的height + padding的上下边距的值 + margin的上下边距的值 + border的上下宽度。

二、css 外边距合并(叠加)

两个上下方向相邻的元素框垂直相遇时,外边距会合并,合并后的外边距的高度等于两个发生合并的外边距中较高的那个边距值,如图:

比较容易理解,所以在页面中有时候遇到实际情况是需要考虑这个因素的。当然外边距合并其实也有存在的意义,如下图:

需要注意的是:只有普通文档流中块框的垂直外边距才会发生外边距合并。行内框、浮动框或绝对定位之间的外边距不会合并。

css reset 中也会经常用到

*{margin:0;padding:0;

}

三、box-sizing属性介绍

box-sizing属性是用户界面属性里的一种,之所以介绍它,是因为这个属性跟盒子模型有关,而且在css reset中有可能会用到它。

box-sizing : content-box|border-box|inherit;

(1)content-box ,默认值,可以使设置的宽度和高度值应用到元素的内容框。盒子的width只包含内容。

即总宽度=margin+border+padding+width

(2)border-box , 设置的width值其实是除margin外的border+padding+element的总宽度。盒子的width包含border+padding+内容

即总宽度=margin+width

很多CSS框架,都会对盒子模型的计算方法进行简化。

(3) inherit , 规定应从父元素继承 box-sizing 属性的值

关于border-box的使用:

1 一个box宽度为100%,又想要两边有内间距,这时候用就比较好

2 全局设置 border-box 很好,首先它符合直觉,其次它可以省去一次又一次的加加减减,它还有一个关键作用——让有边框的盒子正常使用百分比宽度。

四、实际开发中遇到的和框模型相关的应用及小问题。

1 margin越界(第一个子元素的margin-top和最后一个子元素的margin-bottom的越界问题)

以第一个子元素的margin-top 为例:

当父元素没有边框border时,设置第一个子元素的margin-top值的时候,会出现margin-top值加在父元素上的现象,解决方法有四个:

(1)给父元素加边框border (副作用)

(2)给父元素设置padding值  (副作用)

(3)父元素添加 overflow:hidden (副作用)

(4)父元素加前置内容生成。(推荐)

以第四种方法为例:

.parent{width:500px;height:500px;background-color:red;

}.parent : before{content:" ";display:table;

}.child{width:200px;height:200px;background-color:green;margin-top:50px;

}

简述对css盒子模型的理解_css 盒子模型理解相关推荐

  1. 简述对css盒子模型的理解_CSS盒子模型的理解

    一 css盒模型由两个盒子组成,外在的控制是否换行的盒子,以及内在的控制元素内容的盒子. 比如:display: inline-block, 则它的外在的盒子就是inline也就是不占据一行,而blo ...

  2. css3盒子模型微课_CSS 盒子模型

    CSS 盒子模型 CSS 盒子模型(Box Model) 所有HTML元素可以看作盒子,在CSS中,"box model"这一术语是用来设计和布局时使用. CSS盒模型本质上是一个 ...

  3. 「前端早读君007」css进阶之彻底理解视觉格式化模型

    今日励志 不论你在什么时候开始,重要的是开始之后不要停止. 前言 对于部分前端工程师来讲,有时候CSS令他们很头疼,明明设置了某个样式,但是布局就是不起作用. 如果你也有这种问题,那么是时候学习下什么 ...

  4. css知多少(7)——盒子模型

    原文:css知多少(7)--盒子模型 1. 引言 从这一节开始,我们就进入本系列的第三部分--css呈现.本部分将描述css在页面的几种布局和呈现的特性.包括两类:文字.块. 第一类--文字.这部分相 ...

  5. html盒子模型子元素怎么水平占满父元素_CSS盒子模型、溢出处理、浮动、高度坍塌问题...

    盒子模型 1.内容区 width 盒子内容区宽度 height 盒子内容区高度 background-color 背景颜色 盒子可见大小由内容区,内边距和边框共同决定 为元素设置边框,必须指定3个样式 ...

  6. CSS核心内容-标准流、盒子模型、浮动、定位

    CSS核心内容-标准流.盒子模型.浮动.定位,了解了核心内容才能用CSS设计出一个简单的页面 一.基础 在了解核心内容之前需要先了解HTML中的两种标签:块级元素,行内元素: 块级元素:一个块级元素占 ...

  7. 一个简单的css网页换色例子(盒子模型)

    原始的代码来自北京林业大学的MOOC课程:web前端开发,我自己把这个例子又写了一遍,主要是对css部分做了修改(盒子模型杀我),js和HTML部分与课程的源代码基本相同.现在记录一下,首先是代码: ...

  8. 【CSS】盒子边框 ① ( 网页布局本质 | 盒子模型 | 盒子边框 Border | border-width 宽度 | border-style 边框样式 | 边框颜色 | 边框设置综合写法 )

    文章目录 一.网页布局本质 二.盒子模型 三.盒子边框 Border 1.CSS 2.0 文档查询 2.边框设置语法 3.边框设置综合写法 一.网页布局本质 构建一个网页 , 首先 , 创建盒子模型 ...

  9. html中怎么让盒子模型居中,通过box盒子模型给元素内容设置居中

    老版本语法 div{ display: -webkit-box; -webkit-box-align:center; //垂直居中 -webkit-box-pack:center;//水平居中 } 新 ...

最新文章

  1. 一种注册表沙箱的思路、实现——研究Reactos中注册表函数的实现1
  2. Hibernate实现对多个表进行关联查询
  3. Yii2中如何将Jquery放在head中的方法
  4. 如何搭建一个 MySQL 分布式集群
  5. Linux应用--日志定时清理
  6. Heavy Transportation
  7. Android ViewGroup
  8. MySQL的lock tables和unlock tables的用法
  9. 职责链(Chain of Responsibility)模式
  10. 适用于dev中c语言的图形库,Dev-C++中使用EGE图形库
  11. 央行数字货币在技术上是如何实现的
  12. 接口测试(测试用例)
  13. python 小说分析_谁还没看过几本金庸小说?用Python分析一下当年最爱看的主角是谁...
  14. 【渝粤教育】电大中专中药调剂作业 题库
  15. 如何使用Nginx Ingress实现灰度发布和蓝绿发布?
  16. 2021-2027全球与中国外部谷仓门市场现状及未来发展趋势
  17. cve20190708补丁的kb名称_cve-2019-0708漏洞修复补丁下载|
  18. html酷炫电子时钟效果,纯js实现电子时钟特效
  19. el-table 跨行/跨列 的写法
  20. lotus version 0.3.0+git1bfa2311 安装 interopnet

热门文章

  1. java导入excel时去除空行,使用VBA将空行复制到新工作表后删除Excel中的空行
  2. 网络创业者之家:盘点那些不起眼的赚钱机会,成就了大批年轻人。
  3. Saas发展史常用架构
  4. 早餐吃得好,血管更通畅!4种食物都是不错的选择,远离心血管病
  5. 使用python构建数据库_使用Python构建(半)自主无人机
  6. 计算机面试常见题目-网络
  7. AMBER:对单个复合物进行分子动力学模拟的python包(resp计算电荷及gpu加速版本)
  8. 客快物流大数据项目学习框架
  9. 64位服务器系统gho,win7gho
  10. cmd命令打开及切换目录路径