CSS : box-sizing

默认情况下,在CSS框模型中,分配给元素的宽度和高度仅应用于元素的内容框。如果元素具有任何边框或填充,则会将其添加到宽度和高度,以获得在屏幕上呈现的框的大小。这意味着当您设置宽度和高度时,您必须调整您给出的值以允许添加任何边框或填充。
box-sizing属性可用于调整此行为:

  • content-box为您提供默认的CSS框大小调整行为。如果将元素的宽度设置为100像素,则元素的内容框将为100像素宽,并且任何边框或填充的宽度将添加到最终渲染宽度。
  • border-box告诉浏览器在您为元素的宽度和高度指定的值中考虑任何边框和填充。如果将元素的宽度设置为100像素,则100个像素将包含您添加的任何边框或填充,并且内容框将缩小以吸收该额外宽度。这通常会使元素的大小更容易。

句法

:content-box

元素的尺寸计算公式如下:width =内容的宽度,height =内容的高度。(边框和填充不包括在计算中。)

:border-box

元素的尺寸计算如下:width = border + padding +内容的宽度,height = border + padding +内容的高度。

这个例子展示了不同的box-sizing值如何改变其他两个相同元素的渲染大小。

HTML

<div class="content-box">Content box</div>
<br>
<div class="border-box">Border box</div>

CSS

div {
  width: 160px;
  height: 80px;
  padding: 20px;
  border: 8px solid red;
  background: yellow;
}

.content-box { 
  box-sizing: content-box; 
  /* Total width: 160px + (2 * 20px) + (2 * 8px) = 216px
     Total height: 80px + (2 * 20px) + (2 * 8px) = 136px
     Content box width: 160px
     Content box height: 80px */
}

.border-box { 
  box-sizing: border-box;
  /* Total width: 160px
     Total height: 80px
     Content box width: 160px - (2 * 20px) - (2 * 8px) = 104px
     Content box height: 80px - (2 * 20px) - (2 * 8px) = 24px */
}

结果

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,816评论 1 92
  • (注1:如果有问题欢迎留言探讨,一起学习!转载请注明出处,喜欢可以点个赞哦!)(注2:更多内容请查看我的目录。) ...
    love丁酥酥阅读 4,302评论 2 5
  • 学会使用CSS选择器熟记CSS样式和外观属性熟练掌握CSS各种选择器熟练掌握CSS各种选择器熟练掌握CSS三种显示...
    七彩小鹿阅读 6,351评论 2 66
  • 1. 前言 前端圈有个“梗”:在面试时,问个css的position属性能刷掉一半人,其中不乏工作四五年的同学。在...
    YjWorld阅读 4,565评论 5 15
  • 9年以来一直从事翡翠的相关工作。 做的时间久了,发现行内有三个问题非常普遍,而且危害极大。 第一:假货非常多。 无...
    金姑娘阅读 281评论 0 1