盒模型

基本概念

什么是 CSS 盒模型?相信大部分人都能答出这个问题来,那就是 标准模型 + IE 模型

标准模型:

IE 模型

很明显

  • 在 标准盒子模型中,widthheight 指的是内容区域的宽度和高度。增加内边距、边框和外边距不会影响内容区域的尺寸,但是会增加元素框的总尺寸。
  • IE 盒子模型中,widthheight 指的是content+border+padding

CSS 如何设置这两种模型

  • 标准模型:box-sizeing: content-box;
  • IE 模型:box-sizeing: border-box;

JS 如何设置盒模型对应的宽和高

  • dom.style.width/height : 只能取出内联样式的宽和高 eg: <div id="aa" style="width: 200px"></div>
  • dom.currentStyle.width/height 获取即时计算的样式,但是只有 IE 支持,要想支持其他浏览器,可以通过下面的方式
  • window.getComputedStyle(dom).width: 兼容性更好
  • dom.getBoundingClientRect().width/height: 这个较少用,主要是要来计算在页面中的绝对位置

边距重叠

什么是边距重叠呢?

边界重叠是指两个或多个盒子(可能相邻也可能嵌套)的相邻边界(其间没有任何非空内容、补白、边框)重合在一起而形成一个单一边界。

父子元素的边界重叠

  1. <style>
  2. .parent {
  3. background: #e7a1c5;
    //此處為 消除高度塌陷方法之一:padding-top:10px;
  4. }
  5. .parent .child {
  6. background: #c8cdf5;
  7. height: 100px;
  8. margin-top: 10px;
  9. }
  10. </style>
  11. <section class="parent">
  12. <article class="child"></article>
  13. </section>

  14. 解決辦法:在父類元素添加 padding,border,height,width等元素

以为期待的效果:

而实际上效果如下:

在这里父元素的高度不是 110px,而是 100px,在这里发生了高度坍塌。

原因是如果块元素的 margin-top 与它的第一个子元素的 margin-top 之间没有 borderpaddinginline contentclearance 来分隔,或者块元素的 margin-bottom 与它的最后一个子元素的 margin-bottom 之间没有 borderpaddinginline contentheightmin-heightmax-height 分隔,那么外边距会塌陷。子元素多余的外边距会被父元素的外边距截断。

兄弟元素的边界重叠

  1. <style>
  2. #margin {
  3. background: #e7a1c5;
  4. overflow: hidden;
  5. width: 300px;
  6. }
  7. #margin > p {
  8. background: #c8cdf5;
  9. margin: 20px auto 30px;
  10. }
  11. </style>
  12. <section id="margin">
  13. <p>1</p>
  14. <p>2</p>
  15. <p>3</p>
  16. </section>

可以看到 1 和 2,2 和 3 之间的间距不是 50px,发生了边距重叠是取了它们之间的最大值 30px。

空元素的边界重叠

假设有一个空元素,它有外边距,但是没有边框或填充。在这种情况下,上外边距与下外边距就碰到了一起,它们会发生合并:

BFC

解决上述问题的其中一个办法就是创建 BFC。BFC 的全称为 Block Formatting Context,即块级格式化上下文。

  • 处于同一个 BFC 中的元素相互影响,可能会发生 margin collapse;
  • BFC 在页面上是一个独立的容器,容器里面的子元素不会影响到外面的元素,反之亦然;
  • 计算 BFC 的高度时,考虑 BFC 所包含的所有元素,包括浮动元素也参与计算;
  • 浮动盒的区域不会叠加到 BFC 上;

防止垂直 margin 重叠

父子元素的边界重叠得解决方案: 在父元素上加上 overflow:hidden;使其成为 BFC。

  1. .parent {
  2. background: #e7a1c5;
  3. overflow: hidden;
  4. }

兄弟元素的边界重叠,在第二个子元素创建一个 BFC 上下文:

  1. <section id="margin">
  2. <p>1</p>
  3. <div style="overflow:hidden;">
  4. <p>2</p>
  5. </div>
  6. <p>3</p>
  7. </section>

清除内部浮动

  1. <style>
  2. #float {
  3. background: #fec68b;
  4. }
  5. #float .float {
  6. float: left;
  7. }
  8. </style>
  9. <section id="float">
  10. <div class="float">我是浮动元素</div>
  11. </section>

父元素#float 的高度为 0,解决方案为为父元素#float 创建 BFC,这样浮动子元素的高度也会参与到父元素的高度计算:

  1. #float {
  2. background: #fec68b;
  3. overflow: hidden; /*这里也可以用float:left*/
  4. }

自适应两栏布局

  1. <section id="layout">
  2. <style>
  3. #layout {
  4. background: red;
  5. }
  6. #layout .left {
  7. float: left;
  8. width: 100px;
  9. height: 100px;
  10. background: pink;
  11. }
  12. #layout .right {
  13. height: 110px;
  14. background: #ccc;
  15. }
  16. </style>
  17. <!--左边宽度固定,右边自适应-->
  18. <div class="left"></div>
  19. <div class="right"></div>
  20. </section>

在这里设置右边的高度高于左边,可以看到左边超出的部分跑到右边去了,这是由于由于浮动框不在文档的普通流中,所以文档的普通流中的块框表现得就像浮动框不存在一样导致的。

解决方案为给右侧元素创建一个 BFC,原理是 BFC 不会与 float 元素发生重叠。

  1. #layout .right {
  2. height: 110px;
  3. background: #ccc;
  4. overflow: auto;
  5. }

参考 边距重叠与 BFC

內容轉載,侵權必刪

盒模型與BFC的更多相关文章

  1. 神奇的盒模型(BFC)

    上一篇我提到每一个元素都有自己的display属性,其属性值可以改变.其改变的方式,可以利用神奇的css盒模型(BFC). 盒模型,是css可视化格式化系统的基础,可以用于元素定位和网页布局.一个盒模 ...

  2. 十分钟复习CSS盒模型与BFC

    css盒模型与BFC 本文为收集整理总结网上资源 旨在系统复习css盒模型与bfc 节省复习时间 阅读10分钟 什么是盒模型 每一个文档中,每个元素都被表示为一个矩形的盒子,它都会具有内容区.padd ...

  3. 面试 02-CSS盒模型及BFC

    02-CSS盒模型及BFC #题目:谈一谈你对CSS盒模型的认识 专业的面试,一定会问 CSS 盒模型.对于这个题目,我们要回答一下几个方面: (1)基本概念:content.padding.marg ...

  4. 【从0到1学Web前端】CSS定位问题一(盒模型,浮动,BFC) 分类: HTML+CSS 2015-05-27 22:24 813人阅读 评论(1) 收藏

    引子: 在谈到css定位问题的时候先来看一个小问题: 已知宽度(假如:100px)div框,水平居中,左右两百年的分别使用div框填充.且左右div自适应. 效果如下图: 这个问题的难点主要是浏览器宽 ...

  5. css盒模型与bfc与布局与垂直水平居中与css设计模式等

    一.css盒子与布局相关 盒子内部的布局 盒子之间的布局visual formatting 脱离正常流normal flow的盒子的布局 absolute布局上下文下的布局 float布局上下文下的布 ...

  6. 前端面试必备技巧(二)css盒模型及BFC

    CSS盒模型 基本概念:标准模型+IE模型及区别 CSS如何设置这两种模型? JS如何设置获取盒模型对应的宽和高? 实例题(根据盒模型解释边距重叠) BFC边距重叠解决方案 (1)BFC的基本概念:b ...

  7. css盒模型-BFC

    BFC(边距重叠解决方案) 1.BFC的基本概念:块级格式化上下文 2.BFC的原理(说白了就是BFC的渲染规则): 这个规则是什么呢?我觉得大家能说出4点就够了 第一个就是BFC可以解决这个元素的垂 ...

  8. css盒模型:BFC、IFC边距重叠解决方案

    BFC:块级格式化上下文 IFC:行内格式化上下文 实例如下: <div class="out" style="background: red;"> ...

  9. CSS盒模型的深度思考及BFC

    本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 以下是正文. 题目:谈一谈你对CSS盒模型的认识 专业的面试,一定会问 CSS 盒模型 ...

随机推荐

  1. .net 的page的OnInit方法

    /// <summary> /// 重写父类的方法,父类要执行的方法已经被覆盖 /// </summary> /// <param name="e"& ...

  2. 微信开发平台中有个接口是上传多媒体文件,我用的是java 开发的,我怎么样才能在后台实现呢?

    /**      * 文件上传到微信服务器      * @param fileType 文件类型      * @param filePath 文件路径      * @return JSONObj ...

  3. Linux kill/pkill/killall命令详解

    kill kill(terminate a process)命令用来终止指定的进程, 对于一个后台进程就须用kill命令来终止,我们就需要先使用ps/pidof/pstree/top等工具获取进程PI ...

  4. Asp.Net MVC Identity 2.2.1 使用技巧(六)

    使用用户管理器之角色管理 一.建立模型,这里我们其实在之前的技巧(五)已经建好了. 二.建立控制器RolesAdminController 1.在controllers文件夹上点右键>添加> ...

  5. Linux命令--权限管理

    chmod命令 Linux/Unix 的文件调用权限分为三级 : 文件拥有者.群组.其他.利用 chmod 可以藉以控制文件如何被他人所调用. 使用权限 : 所有使用者 语法 chmod [-cfvR ...

  6. iOS--性能优化--保持界面流畅

    卡顿产生的原因和解决方案 在 VSync 信号到来后,系统图形服务会通过 CADisplayLink 等机制通知 App,App 主线程开始在 CPU 中计算显示内容,比如视图的创建.布局计算.图片解 ...

  7. gluoncv voc_detection

    https://github.com/zhreshold/gluon-cv/commit/73b3986aaa2e0d0e6f3f428c12072e3a9d29905e gluoncv可能版本还没更 ...

  8. 随手练——洛谷-P1008 / P1618 三连击(暴力搜索)

    1.普通版 第一眼看到这个题,我脑海里就是,“我们是不是在哪里见过~”,去年大一刚学C语言的时候写过一个类似的题目,写了九重循环....就像这样(在洛谷题解里看到一位兄台写的....超长警告,慎重点开 ...

  9. 浅谈MVP架构及开发模式

    Model-View-Presenter(MVP)概述    MVC模式已经出现了几十年了,在GUI领域已经得到了广泛的应用,由于微软ASP.NET MVC Framework的出现,致使MVC一度成 ...

  10. 非接触式读卡器13.56MHZ芯片:SI522

    对于现在的智能锁市场需求竞争极大,中小型厂家月销量更是在慢慢增长.刷卡功能更是智能锁的标配功能,当然13.56Mhz芯片现在讲究的就是超低功耗,为满足市场需求专注于物联网多年的中科微强力推出了13.5 ...