zoukankan      html  css  js  c++  java
  • CSS盒模型

    html文档被浏览器解析之后会构造一棵DOM树,文档中的每个html元素会变成DOM树上的节点,然后浏览器便要将这棵树绘制出来。为了方便节点的渲染,我们将每个节点看做一个盒子,如下图。

    盒模型

    盒模型有三种:

    • W3C提出的标准盒模型(content-box)
    • IE的怪异盒模型(border-box)
    • padding-box

    在两种盒模型中元素所占据的区域大小都是由padding、margin、boder、内容宽、内容高决定的。

    两种盒模型的区别主要在于对元素宽高的定义,即CSS中的width和height属性在不同盒模型状态下所指代的意义是不同的。

    下面对两种盒模型进行详细说明。


    标准盒模型(content-box)

    content-box

    在标准盒模型中:

    元素实际宽度 = width + padding-left + padding-right + border-left + border-right + margin-left + margin-right
    元素实际高度 = height + padding-top + padding-bottom + border-top + border-bottom + margin-top + margin-bottom

    说明:width、height指的是图中的content区域的宽和高。


    怪异盒模型(border-box)

    border-box

    在怪异盒模型中:

    元素实际宽度 = width + margin-left + margin-right
    元素实际高度 = height + margin-top + margin-bottom

    说明:

    width = content宽度 + padding-left + padding-right + border-left + border-right
    height = content高度 + padding-top + padding-bottom + border-top + border-bottom


    padding-box

    在padding-box模型中:

    元素实际宽度 = width + margin-left + margin-right + border-left + border-right
    元素实际高度 = height + margin-top + margin-bottom + border-top + border-bottom

    说明:

    width = content宽度 + padding-left + padding-right
    height = content高度 + padding-top + padding-bottom


    总结

    在CSS3中可以使用box-sizing属性进行选择,现在开发过程中渲染依照标准盒模型渲染,但是当元素设置为浮动时,元素采用padding-box渲染

    三者主要的区别在于宽高的定义。

    标准盒模型:

    width = content宽
    height = content高

    padding-box:

    width = content宽 + border
    height = content高 + border

    怪异盒模型:

    width = content宽 + border + padding
    height = content高 + border + padding

    推荐文章

  • 相关阅读:
    端午节
    使用MetaWeblog写博客
    Ajax 跨域操作
    MetaWeblogApi 开发, 离线写博客
    大三开学
    JVM003ConcurrentHashMap底层原理是什么
    JVM009JVM性能调优概述
    JVM006Java类加载器有哪些
    JVM004GC如何判断对象可以被回收
    JVM008JVM内存结构如何划分
  • 原文地址:https://www.cnblogs.com/zhangkaiqiang/p/5875305.html
Copyright © 2011-2022 走看看