两列布局

一、常见的两列布局

如百度搜索结果页面,两列固定宽度,高度自适应。

两列布局_第1张图片

 博客园文章内容页面和上边的结构类似。

二、实现两列布局步骤

1)应用浮动

 CSS如下

*{margin:0;padding:0;}
#header,#footer{width:960px; height:40px; background-color:#f0f0f0; margin:0 auto;}
#drapper{ width:960px;  margin:10px auto;}
 
.mainBox{float:left; width:680px;  background-color:red;}
.sidebar{float:right; width:270px;background-color:red;}

  我们的html结构一般是这样的

复制代码
<div id="header">header</div>
<div id="drapper">
<div class="mainBox">
下午在创新工场听赖晓宁的分享,他说到 O2O 这个领域,如果你只是做简单的线上引流到线下,是没有多少机会的,能赚个 1、2 年钱不错了。真正重要的,是完全拆解掉线下的利益链条,按你的逻辑重新组装起来,这样才有壁垒。
</div>
<div class="sidebar">想革传统行业的命?你得先拆解开原有链条,再重构新格局</div>
<div style="clear:both;"></div>
</div>


<div id="footer">footer</div>
复制代码

 

  两列布局_第2张图片

现在样式中浮动的div是没有设置高度的,设置左浮动的div高度为50pxj后,内容超出高度会发生什么?

两列布局_第3张图片

因此,浮动的div最好不要固定高度,或者固定高度后,添加overflow:hidden;

2)高度自适应

高度自适应就是不设置高度,或者height:auto;

3)清楚浮动

百度搜索或者博客园内容页都是在浮动div后边添加了一个多余的div标签。一般清楚浮动可以处理。

有人就说了,直接将footer加clear:both;不是也可以吗?

两列布局_第4张图片

仔细看还是有区别的,只给footer加浮动浮动,div的容器drapper设置的外边距不起作用了。

三、一列固定宽度,一列自适应

一列固定必须使用固定宽度px,自适应的话使用%来控制宽度,比如sidebar 200px,mainBox70%,但是如果将浏览器可视区域缩小,则sidebar又挤到下边了。最好用width:auto或者100%并且配合负margin,此时也有问题当窗口减小,sidebar内容和mainBox出现内容重叠的情况。此时可以用定位方式来解决该问题。修改后的css如下

*{margin:0;padding:0;}
#header,#footer{width:auto; height:40px; background-color:#f0f0f0; margin:0 auto;}
#drapper{ width:auto;  margin:10px auto; position:relative;}

.mainBox{float:left; width:auto; background-color:red; margin-right:275px;}
.sidebar{float:right; width:270px;background-color:red; position:absolute;top:0px;right:0px;}

 

可视窗口变化后的显示效果

两列布局_第5张图片

两列布局_第6张图片

四、两列宽度自适应

这种布局方式,直接给浮动的div分配一定的宽度比例即可,如mainBox 70%,sidebar 28%。随着视窗的改变,两列一直按照比例进行显示,不会出现重叠或者一方被”挤到下方”的情况。

 

笔分类 - HTML&CSS

 
摘要: 一、常见的两列布局如百度搜索结果页面,两列固定宽度,高度自适应。博客园文章内容页面和上边的结构类似。二、实现两列布局步骤1)应用浮动CSS如下*{margin:0;padding:0;}#header,#footer{width:960px; height:40px; background-colo... 阅读全文
posted @  2014-11-06 16:35 Buller Lee 阅读(251) |  评论 (0)  编辑
摘要: 开场白 我们平时工作中,很容易遇到浮动效果。一个DIV中嵌套多个DIV,左边显示一个DIV,右边显示一个DIV,外层DIV的高度随着内层内容的高度变化。这就是最基本的浮动效果。下图的百度搜索结果就是一个简单的例子。什么是CSS清除浮动? 借用W3C的定义。浮动的框可以向左或向右移动,直到它的外边... 阅读全文
posted @  2014-09-21 22:25 Buller Lee 阅读(11) |  评论 (0)  编辑
摘要: 开场白 CSS3相对于CSS2引入了很多的新的css属性和特效,利用css3实现了原来需要加入js才能模拟的效果,因此前端性能提高了很多。各大浏览器厂商包括IE都逐渐的加大对CSS3 HTML5的支持,移动web前端的火热形式也对HTML5 CSS3起到了极大的推动作用。一、快捷的CSS3样式选择... 阅读全文
posted @  2014-09-04 21:13 Buller Lee 阅读(10) |  评论 (0)  编辑
分类:  HTML&CSS

你可能感兴趣的:(布局)