曾经在江湖上盛传的双飞翼布局,无人不知,无人不晓。大概的意思就是左右两边盒子固定宽度,剩下中间部分自由缩放,考虑到通常网站的主体部分在中间,用户首先须要看到的是中间部分。因此将中间的div放在最上方,以下图所示。css
// HTML部分 <div class="container"> <div class="main"> <p>主内容栏自适应宽度</p> </div> <div class="aside-1"> <p>侧边栏1固定宽度</p> </div> <div class="aside-2"> <p>侧边栏2固定宽度</p> </div> </div> //css部分 .container { position: relative; width: 100%; } .container > div { position: absolute; } .main { width: 100%; padding: 0 200px; box-sizing: border-box; } .aside-1 { width: 200px; top: 0; left: 0; } .aside-2 { width: 200px; top: 0; right: 0; }
双飞翼布局是IE6横行时期,人们不得已采用的方法,很差理解,写起来也很麻烦。今天我运用两种如今浏览器支持的css属性,简化一下代码。html
// html <div class="container"> <div class="main"> <div class="middle"> 主内容栏自适应宽度 </div> </div> <div class="aside-1"> <p>侧边栏1固定宽度</p> </div> <div class="aside-2"> <p>侧边栏2固定宽度</p> </div> </div>
第一种:前端
// 利用flex布局的order属性,轻松实现。 .container { display: flex; width: 100%; } .main { flex: 1; order: 2; } .aside-1 { flex: 0 0 200px; order: 1; } .aside-2 { flex: 0 0 200px; order: 3; }
//利用绝对定位,加上box-sizing,也能实现的效果。 .container { width: 100%; } .container > div { float: left; } .main { width: 100%; } .middle { margin: 0 200px; } .aside-1 { width: 200px; margin-left: -100%; } .aside-2 { width: 200px; margin-left: -200px; }
如上可知,随着前端发展的滚滚大潮所谓的双飞翼、圣杯布局中间会被历史淘汰,迎来新的时期。浏览器