css虽简单,但细节多,技巧性高,易学难精。
如何实现左右固定300px , 中间宽度自适应?
有如下结构
<div class="wrapper">
<div class="item left">左</div>
<div class="item right">右</div>
<div class="item center">中</div>
</div>
公有样式, 设置高,设置左右宽度固定300px,左右为红色,中间为黄色。
.item {
height: 400px;
}
.left,
.right {
width: 300px;
background: #f00;
}
.center {
background: yellow;
}
一. 双浮动法
.left {
float: left;
}
.right {
float: right;
}
原理: float不会完全脱离文档流,会占用原空间
MDN官方解释:该元素从网页的正常流动(文档流)中移除,尽管仍然保持部分的流动性(与绝对定位相反)。
问: 为什么 center 要放在leftr和right之后?
答:
浏览器加载页面顺序是从上到下,
left已经左浮动,right右浮动。渲染center时