今天看了一些关于box-sizing的一些资料,在这里整理一下,但愿也能对你们有所帮助。css
box-sizing是CSS的一个属性,很好的解决了盒模型的相关问题。CSS中的盒模型(Box model)分为两派,一派是W3C的标准模型,一派是IE的传统模型。那它们之间有什么不一样的呢?首先须要明确它们都是对元素计算尺寸的模型,具体说就是对元素的width,height,padding,border以及元素实际尺寸的计算关系;而不一样的地方就在于二者的计算方法不一至:(下面引用一些公式向你们展现一下二者的不一样之处)web
W3C的标准盒模型浏览器
IE传统盒模型(IE6如下不含IE6版本或“QuirksMode下IE5.5+”)布局
接下来直接看看box-sizing的应用吧。ui
box-sizing属性能够分为两个值:content-box(default),border-box。rest
content-box,border和padding不计算入width以内blog
border-box,border和padding计算入width以内it
(注1:ie8+浏览器支持content-box和border-box;ff则支持所有三个值)model
(注2:使用时,有些浏览器仍是须要加上本身的前缀,Mozilla须要加上-moz-,Webkit内核须要加上-webkit-,Presto内核-o-,IE8-ms-)webkit
栗子,接住:
<style type="text/css">
.content-box{
-webkit-box-sizing:content-box;
width: 100px;
height: 100px;
padding: 20px;
border: 5px solid #E6A43F;
background: blue;
}
.border-box{
-webkit-box-sizing:border-box;
width: 100px;
height: 100px;
padding: 20px;
border: 5px solid #3DA3EF;
background: yellow;
}
</style>
我是在谷歌下运行的,因此加了-webkit-前缀,效果以下:
蓝色加边框:总宽150px,高150px
黄色加边框:总宽100px,高100px
经过这一栗子,相信你们弄清楚了这两个。与刚才给你们说起的两派盒子模型联系看看,总结得出:content-box至关于W3C下的模式,而border-box则为传统IE下的模式了。这样你们就能够解决一些布局上的难题了吧。固然,box-sizing的更多实际运用,在这里就很少说了,在次抛砖而已,献上。