zoukankan      html  css  js  c++  java
  • 盒模型與BFC

    盒模型

    基本概念

    什么是 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=" 200px"></div>
    • dom.currentStyle.width/height 获取即时计算的样式,但是只有 IE 支持,要想支持其他浏览器,可以通过下面的方式
    • window.getComputedStyle(dom).width: 兼容性更好
    • dom.getBoundingClientRect().width/height: 这个较少用,主要是要来计算在页面中的绝对位置

    边距重叠

    什么是边距重叠呢?

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

    父子元素的边界重叠

    <style>
      .parent {
        background: #e7a1c5;
    //此處為 消除高度塌陷方法之一:padding-top:10px; }
    .parent .child { background: #c8cdf5; height: 100px; margin-top: 10px; } </style> <section class="parent"> <article class="child"></article> </section>
    解決辦法:在父類元素添加 padding,border,height,width等元素

    以为期待的效果:

    而实际上效果如下:

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

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

    兄弟元素的边界重叠

    <style>
      #margin {
        background: #e7a1c5;
        overflow: hidden;
         300px;
      }
      #margin > p {
        background: #c8cdf5;
        margin: 20px auto 30px;
      }
    </style>
    <section id="margin">
      <p>1</p>
      <p>2</p>
      <p>3</p>
    </section>
    

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

    空元素的边界重叠

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

    BFC

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

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

    防止垂直 margin 重叠

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

    .parent {
      background: #e7a1c5;
      overflow: hidden;
    }
    

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

    <section id="margin">
        <p>1</p>
        <div style="overflow:hidden;">
            <p>2</p>
        </div>
        <p>3</p>
    </section>
    

    清除内部浮动

    <style>
      #float {
        background: #fec68b;
      }
      #float .float {
        float: left;
      }
    </style>
    <section id="float">
      <div class="float">我是浮动元素</div>
    </section>
    

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

    #float {
      background: #fec68b;
      overflow: hidden; /*这里也可以用float:left*/
    }
    

    自适应两栏布局

    <section id="layout">
      <style>
        #layout {
          background: red;
        }
        #layout .left {
          float: left;
           100px;
          height: 100px;
          background: pink;
        }
        #layout .right {
          height: 110px;
          background: #ccc;
        }
      </style>
      <!--左边宽度固定,右边自适应-->
      <div class="left">左</div>
      <div class="right">右</div>
    </section>
    

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

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

    #layout .right {
      height: 110px;
      background: #ccc;
      overflow: auto;
    }
    

    参考 边距重叠与 BFC

    內容轉載,侵權必刪

  • 相关阅读:
    HTML基础(一)基本语法知识
    本地方法接口
    本地方法栈
    虚拟机栈相关的问题
    栈帧的内部结构--一些附加信息
    基于角色的权限控制设计
    SpringBoot普通消息队列线程池配置
    栈帧的内部结构--动态返回地址(Return Address)
    栈帧的内部结构--动态链接 (Dynamic Linking)
    栈帧的内部结构--操作数栈(Opreand Stack)
  • 原文地址:https://www.cnblogs.com/zhangdzz/p/10515867.html
Copyright © 2011-2022 走看看