百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>CSS教程> css自适应左右两样布局实现
分享文章到:

css自适应左右两样布局实现

发布时间:01/15 来源: 浏览: 关键词:
文章介绍一了个的css实现自适应左右布局的实现有需要了解的朋友可以参考一下。

实例

 代码如下

<style type="text/css">
body,div,h3,p{margin:0;padding:0;}
.fl{float:left;display:inline;}
.fr{float:right;display:inline;}
.cl{clear:both;}

.container{width:250px;margin:60px auto 0;}
.col_rigid{width:62px;height:62px;float:left;background:url('gh.png');}
.col_flexible{margin-left:72px;}
</style>

下面为主体部份

<div class="container">
 <div class="col_rigid"></div>
 <div class="col_flexible">右边宽度自适应,修改container的width值试试。</div>
</div>
<div class="container">
 <div class="col_rigid"></div>
 <div class="col_flexible">
  <div>
   <h3 class="fl">我左浮动</h3><a class="fr" href="#">我右浮动</a>
   <div class="cl"></div>
  </div>
  <p>我是内容</p>
 </div>
</div>

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;}

效果如下图所示:

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

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

 

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

 

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

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

如图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><a class="fr" href="#">我右浮动</a>
  </div>
  <p>我是内容</p>
</div>

总结:在自适应左右时我们只要把div的display修改为display:inline;这样我们再利用float:left和rigth来左右浮动,这样只要宽度不越出父容器宽度就可以实现自适应两栏布局了。

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有14人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板