zoukankan      html  css  js  c++  java
  • border-sizing属性详解和应用

    box-sizing用于更改用于计算元素宽度和高度的默认的 CSS 盒子模型。它有content-boxborder-boxinherit三种取值。inherit指的是从父元素继承box-sizing表现形式,不再冗赘。

    1. 属性讲解

    content-box

    默认值,也是css2.1中的盒子模型。在计算widthheight时候,不计算borderpaddingmargin高度、宽度都只是内容高度

    border-box

    css3新增。 widthheight属性包括内容,内边距和边框,但不包括外边距。

    计算公式:

    1. width = width = border + padding + 内容宽度
    2. height = border + padding + 内容高度

    2. 考虑盒子模型的margin

    从上面可以知道,即时是border-box也是不计算margin,只是多余计算了borderpadding因为borderpadding都是盒子模型的一部分,但是margin标记的是盒子和盒子的间距。所以,border-box的解释很符合常理。

    问题来了,如果有时候一定要设置margin怎么做到自由控制来保证兼容?例如,我们下面要设置一个撑满页面的盒子元素,而且有外边距干扰,怎么做?

    实现如下效果图:
    border-sizing属性详解和应用

    代码:源码下载

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <meta http-equiv="X-UA-Compatible" content="ie=edge">
      <title>yuanxin.me</title>
      <style type="text/css">
        *{
          margin: 0;
          padding: 0;
        }
        #app {
          box-sizing: border-box; /* 指定计算方式 */
          margin: 10px; /* 外边距干扰 */
          /* 利用 css3 的 calc */
           calc(100vw - 2*10px);
          height: calc(100vh - 2*10px);
        }
      </style>
    </head>
    <body>
      <div id="app">
      </div>
    </body>
    </html>
    

    所以,当需要计算外边距(margin),可以配合css3中的四则运算(calc)来使用

    3. 使用建议

    根据项目中的使用经验和w3c的建议,推荐将box-sizing属性设置为border-box

    * {
      margin: 0;
      padding: 0;
    }
    div {
      box-sizing: border-box;
    }
    

    4. 关于

    欢迎技术交流,引用请注明出处。
    个人网站:godbmw.com
    原文链接:border-sizing属性详解和应用

  • 相关阅读:
    高斯滤波
    最短路径与贪婪
    应该要知道的几个统计学定义.
    Linux network setting.
    Windows与自定义USB HID设备通信说明.
    Win32 WriteFile and ReadFile
    C语言原码反码补码与位运算.
    Linux下查看显示器输出状态以及修改显示器工作模式(复制 or 扩展)
    Web通信协议:OSI、TCP、UDP、Socket、HTTP、HTTPS、TLS、SSL、WebSocket、Stomp
    如何用搜狗拼音输入法输入希腊字母及各种上下标
  • 原文地址:https://www.cnblogs.com/geyouneihan/p/9377204.html
Copyright © 2011-2022 走看看