美文网首页我爱编程
box-sizing 的用法

box-sizing 的用法

作者: 小杰的简书 | 来源:发表于2018-04-10 20:06 被阅读0次

    聊聊几乎已成为现代事实标准的“box-sizing: border-box”

    2017.05.22 10:51* 字数 957 阅读 131评论 0喜欢 3

    了解盒子模型

    盒子模型的概念不在此讲述,但是了解“box-sizing: border-box”的前提就是了解盒子模型。

    “box-sizing: border-box”是什么东西

    “box-sizing: border-box”是一个CSS 3声明,可能一些开发者都不曾听过这个CSS声明,更没有用过,这个前提下,你眼中的盒子模型,应该是标准模型,也就是说,你一直在使用标准盒子模型,它的最大特点是,当已经设定了width和height值的时候,padding和border不被包含在定义的width和height之内,也就是说,你设的width只负责content区域的宽度,如果想得到盒子宽度,需要再加上padding和border的厚度。也就是说,你的容器默认使用了box-sizing: content-box,content-box顾名思义,就是内容盒子。

    那么今天要说的“box-sizing: border-box”,顾名思义,就是边框盒子,也就是说,边框和边框内的padding,都算在width值和height值之内。

    既然标准盒子模型诞生的早,又叫做标准盒子模型,为什么CSS 3中还要新增一个“border-box”呢?

    content-box的缺点

    content-box的最大缺点就是:当你想让两个子容器float:left,宽度各50%,然后给一点padding,最后让子容器并排充满父容器,一切想的挺美好,然而你发现结果并不是这么美好,因为子容器的盒子宽度已经超出了父容器的一半,导致了折行,于是,width就不能50%了,只能是50%再减去padding的像素值。是不是很不幸福?

    border-box的优势

    border-box的诞生,主要就是解决content-box的最大缺点。border-box意味着子容器的padding和border的厚度都算在50%之内,这样,你可以随意的修改padding和border的厚度值,根本不用担心父容器被撑爆。

    border-box的兼容性

    IE8已经支持border-box,所以兼容性不是问题。

    border-box是事实的标准?

    现在最著名的CSS框架几乎都采用了border-box,所以它才是事实的标准。框架想要具备栅格系统,就肯定要去使用border-box,如果用content-box会有一种想死的感觉。

    怎么用border-box

    box-sizing属性是不具备继承性的,原因很简单,box-sizing属性本来就应该是灵活使用的,全局设定为border-box或者全局设定为content-box都有弊端。

    假如你确定你的页面整体或者某个大块的所有元素都应当用上border-box,那么你应该搞一个:

    * {box-sizing: border-box;}

    或者搞一个:

    #某id* {box-sizing: border-box;}

    通常情况下,上面这种代码是没必要加的,事实上:你只需要在应当使用border-box的元素身上使用border-box,其他的元素保持content-box就好了。

    border-box的使用场合

    子元素有padding和border,或者至少有其一,并且需要给子元素设定100%宽度(或者50%宽度等等),这时候显然需要border-box。设为border-box之后,padding和border的厚度可以随意调,并不会溢出父元素。如果是content-box,那么,宽度必然会溢出,而且,为了不溢出,你设定子元素的宽度就只能是一个定值,或者是一个计算值(比如calc(100% - 20px))。

    相关文章

      网友评论

        本文标题:box-sizing 的用法

        本文链接:https://www.haomeiwen.com/subject/wuanhftx.html