这篇文章给大家介绍的文章内容是关于css中border-sizing属性的用法,有很好的参考价值,希望可以帮助到有需要的朋友。
box-sizing用于更改用于计算元素宽度和高度的默认的 CSS 盒子模型。它有content-box、border-box和inherit三种取值。inherit指的是从父元素继承box-sizing表现形式,不再冗赘。
## 1. 属性讲解
#### content-box
默认值,也是css2.1中的盒子模型。在计算width和height时候,不计算border、padding和margin。高度、宽度都只是内容高度。
#### border-box
css3新增。 width和height属性包括内容,内边距和边框,但不包括外边距。
立即学习“前端免费学习笔记(深入)”;
计算公式:
width = width = border + padding + 内容宽度
height = border + padding + 内容高度
## 2. 考虑盒子模型的margin
从上面可以知道,即时是border-box也是不计算margin,只是多余计算了border和padding。因为border和padding都是盒子模型的一部分,但是margin标记的是盒子和盒子的间距。所以,border-box的解释很符合常理。
问题来了,如果有时候一定要设置margin,怎么做到自由控制来保证兼容?例如,我们下面要设置一个撑满页面的盒子元素,而且有外边距干扰,怎么做?
代码:源码下载
nbsp;html>yuanxin.me *{ margin: 0; padding: 0; } #app { box-sizing: border-box; /* 指定计算方式 */ margin: 10px; /* 外边距干扰 */ /* 利用 css3 的 calc */ width: calc(100vw - 2*10px); height: calc(100vh - 2*10px); }
登录后复制
所以,当需要计算外边距(margin),可以配合css3中的四则运算(calc)来使用。
## 3. 使用建议
根据项目中的使用经验和w3c的建议,推荐将box-sizing属性设置为border-box。
* { margin: 0; padding: 0;}p { box-sizing: border-box;}
登录后复制
相关推荐:
如何用纯CSS实现动态行驶的火车
css选择符有哪些?css选择符的全面总结(附代码)
以上就是css中border-sizing属性的用法的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2894723.html