zoukankan      html  css  js  c++  java
  • 自适应两栏布局的最简实现

    下载本示例代码

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

    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>

    PS:因为自适应宽度一栏不能使用清除浮动,所以该布局不能够用于页面的整体布局。关于页面的整体布局,请阅读我的另一篇文章:很酷的页面布局框架

    好,大功告成,谢谢阅读!: )

  • 相关阅读:
    47.一个h5画板
    46.纯css实现瀑布流(flex)
    45.使用webpack,react,redux搭俩个界面
    44.一个这样的datePicker
    43.关于浮点数的乘除法预算误差,一个看似没什么问题的解决方法
    iOS10 NSBundle
    iOS09-NSUserDefault
    iOS08 页面跳转动画设置方法
    iOS07 键盘弹出,回收,位置
    iOS06 NSTimer 详细设置1
  • 原文地址:https://www.cnblogs.com/andycja/p/2483275.html
Copyright © 2011-2022 走看看