深入了解css3 border-sizing属性


本文摘自PHP中文网,作者青灯夜游,侵删。

推荐:css视频教程

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

1. 属性讲解

content-box

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

border-box

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

计算公式:

  • width = width = border + padding + 内容宽度

  • height = border + padding + 内容高度

2. 考虑盒子模型的margin

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

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

实现如下效果图:

1.png

代码:源码下载

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

<!DOCTYPE html>

<html>

<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 */

      width: 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

1

2

3

4

5

6

7

* {

  margin: 0;

  padding: 0;

}

div {

  box-sizing: border-box;

}

更多编程相关知识,请访问:编程入门!!

以上就是深入了解css3 border-sizing属性的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

clevercss是什么?

利用css绘制三角形的6种技巧(分享)

css如何制作三角形

css怎么让div垂直居中

css的三种样式形式?

css实现禁止页面文字被选中功能

css设置文字外发光效果

为什么css要初始化

vue的源码解析(代码示例)

css中的display是什么意思

更多相关阅读请进入《css》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...