我今天在一次讨论中出现,我想知道将两个 div 放在一起的最高效的方式是什么。
一方面,我喜欢使用display:flex;
,另一方面有使用的选项calc()
,原因是我们的 div 有填充,我们需要通过填充来减小宽度。案子:
<div class='container'>
<div class='inner'></div>
<div class='inner'></div>
</div>
两者都应该是 50% 的宽度。默认的CSS是:
* {
-webkit-box-sizing: border-box; /* Safari/Chrome, other WebKit */
-moz-box-sizing: border-box; /* Firefox, other Gecko */
box-sizing: border-box; /* Opera/IE 8+ */
}
.container {
height: 100%;
width: 100%;
}
.inner {
width: 50%;
padding: 20px;
}
方式将display:flex;
是额外的:
.container {
display: -webkit-box;
display: -moz-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
flex-wrap: nowrap;
align-items: stretch;
align-content: stretch;
}
calc()
方法是:
.inner {
width: calc(100% - 40px);
display: inline-block;
}
或者:
.inner {
width: calc(100% - 40px);
float: left;
}
我不希望我的 CSS 中有任何表格布局。此外,我们不需要关心浏览器版本,这应该始终只在最新版本中起作用。
推荐使用什么?什么性能更高?
我已经找到一篇文章,性能已经提高了很多。关联