圣杯布局(传智播客)
2018-08-27 本文已影响347人
李chun
本教程来源 传智播客 的视频教程
data:image/s3,"s3://crabby-images/6b8fc/6b8fc2a3c92006f125a1fa70216b8392e1fd4c32" alt=""
data:image/s3,"s3://crabby-images/73be1/73be14d9cd5e876368e911c998098d8f2d1ec1a3" alt=""
效果图
data:image/s3,"s3://crabby-images/d15d8/d15d89fad5231b1ea57453185004b72851892c32" alt=""
圣杯布局
固比固(两侧固定宽度,中间宽度百分比自适应)
data:image/s3,"s3://crabby-images/9c18d/9c18d66b0934df276598cd3c37015888f3dc90f3" alt=""
data:image/s3,"s3://crabby-images/e8fc5/e8fc55a8abf675ac57e7de9ddae7334b0d1fbca2" alt=""
data:image/s3,"s3://crabby-images/b7066/b70661fada3e04b01b363522bccf75374df37afa" alt=""
过程步骤
0
现在有一个父容器.container和左中右三个子盒子,.main .left .right ,先写第二个盒子.
给他们设置宽高和背景颜色
html结构
<body>
<div class="container">
<div class="main">main中间自适应</div>
<div class="left">left固定宽度</div>
<div class="right">right固定宽度</div>
</div>
</body>
data:image/s3,"s3://crabby-images/9fe1b/9fe1b3adfbb9d3420488d456d7f0e316e42a1a0f" alt=""
1
使子盒子都浮动,给父容器加清除浮动overflow: hidden;zoom: 1
data:image/s3,"s3://crabby-images/68674/6867481ef5a5305ea755ead1c5b2536bb877772e" alt=""
data:image/s3,"s3://crabby-images/83c5e/83c5eaf78a652fb916ff374055d985375ad599d0" alt=""
2
设置.left和.right的margin-left,让他们压到.面的左右两边.
data:image/s3,"s3://crabby-images/95a96/95a967ac50864080b14bbb389b5eda2973fb985d" alt=""
data:image/s3,"s3://crabby-images/657a3/657a39b8b86f016d03390d37c5c491e194ab43e3" alt=""
data:image/s3,"s3://crabby-images/600a5/600a51aafa145e4c881260716fbe36d62e5809c1" alt=""
3
.container设置左右padding,把三个子盒子压挤到中间
data:image/s3,"s3://crabby-images/b2c02/b2c02e0f8160aaee61029e2fde20506ecfacd160" alt=""
data:image/s3,"s3://crabby-images/b57df/b57dfe3a1309f87f8086fec27380738d6fe2311c" alt=""
data:image/s3,"s3://crabby-images/9ee55/9ee55359650bdfbf398c44ec04125a1d0eccc14e" alt=""
4
让.left相对自己现在位置往左移动,让.right相对自己现在位置往右移动.
data:image/s3,"s3://crabby-images/984b7/984b7d2ad210076ff919f38c1761b823677da305" alt=""
data:image/s3,"s3://crabby-images/110c2/110c29c6bd3a53ba03e621c49ce401394844f323" alt=""
data:image/s3,"s3://crabby-images/2914f/2914fe1cb6b6715a5c3cfeb7871827d9ee4cda96" alt=""
代码
data:image/s3,"s3://crabby-images/37900/37900c582411b9e5547b5775d52dc5bddfc63d3d" alt=""
data:image/s3,"s3://crabby-images/c44d2/c44d2a5d51aaeb961b94ac64a8032db25be58ea4" alt=""
index.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<link rel="stylesheet" type="text/css" href="index.css"/>
</head>
<body>
<!--此参考教程 传智播客 的讲圣杯布局和双飞翼布局-->
<div class="container">
<div class="main">main中间自适应</div>
<div class="left">left固定宽度</div>
<div class="right">right固定宽度</div>
</div>
</body>
</html>
index.css
/*预处理body,最小宽度*/
body{margin: 0;padding: 0;color: #fff;text-align: center; min-width: 800px;}
/*主容器,清除浮动*/
.container{overflow: hidden;zoom: 1;padding-left: 200px;padding-right: 90px;}
/*宽度,高度,背景颜色*/
.main{width: 100%;height: 200px;background: #CCCC33;
float: left
}
.left{width: 200px;height: 230px;background: #0000FF;
float: left;margin-left: -100%;
position: relative;left: -200px;}
.right{width: 90px;height: 230px;background: #800080;
float: left;margin-left: -90px;
position: relative;left: 90px;}