打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
自适应两栏布局的最简实现

本实现一栏宽度固定,另一栏宽度随父元素宽度的变化而变化。代码极其简单。

Html代码只是两个div:

<div class="col_rigid"></div>
<div class="col_flexible"></div>

Css代码就两个class:

.col_rigid{width:62px;height:62px; }
.col_flexible
{margin-left:72px;}

效果如下图所示:

 

                图 1-1

本实现非常简洁,但有些负面问题需要提醒注意。

假设我们想实现如下效果:

                图 1-2

通常我们需要在浮动元素下面使用清除元素,代码是这样写的:

<div class="col_rigid"></div>
<div class="col_flexible">
  <div>
    <h3 class="fl">我左浮动</h3><class="fr" href="#">我右浮动</a>
    <div class="cl"></div>
  </div>
  <p>我是内容</p>
</div>

但意外的是代码没有像我们想要的方式工作,它的呈现效果如下:

 

                图 1-3

如图1-3,实际的结果是右栏中浮动元素后面的内容被清除到了左栏底边之下,致使右栏中浮动元素之后出现一大片空白。说明一下,这可不是IE或者某种浏览器的bug,而是html标准就是这样的。具体请见我翻译的文章清除浮动的新方法

就是说在右栏中我们不能使用清除浮动了,那么怎么才能实现我们想要的图1-2的效果呢?可以通过在右栏的浮动行div元素上固定高度来实现。代码如下:

<div class="col_rigid"></div>
<div class="col_flexible">
  <div style="height:30px;">
    <h3 class="fl">我左浮动</h3><class="fr" href="#">我右浮动</a>
  </div>
  <p>我是内容</p>
</div>
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
CSSBFC规则的应用自适应两栏布局
网页栅格系统研究(4):技术实现
bootstrap布局之解决间隔问题
css负边距之详解
整理高度塌陷与BFC
使用WordPress导航CSS类花式玩耍菜单栏
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服