浅析两列自适应布局的3种思路

  发布时间:2016-05-03 15:47:19   作者:佚名   我要评论
下面小编就为大家带来一篇浅析两列自适应布局的3种思路。小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

前面已经介绍过单列定宽单列自适应的两列布局,而两列自适应布局是指一列由内容撑开,另一列撑满剩余宽度的布局方式。本文将从float、table和flex来介绍两列自适应布局的3种思路。

思路一: float

在单列定宽单列自适应的两列布局中,经常用float和负margin配合实现布局效果。但由于margin取值只能是固定值,所以在两列都是自适应的布局中就不再适用。而float和overflow配合可实现两列自适应效果。使用overflow属性来触发bfc,来阻止浮动造成的文字环绕效果。由于设置overflow:hidden并不会触发IE6-浏览器的haslayout属性,所以需要设置zoom:1来兼容IE6-浏览器

CSS Code复制内容到剪贴板
  1. <style>   
  2. p{margin: 0;}   
  3. .parent{overflowhidden;zoom: 1;}   
  4. .left{floatleft;margin-right20px;}       
  5. .rightright{overflowhidden;zoom: 1;}   
  6. </style>  

 

XML/HTML Code复制内容到剪贴板
  1. <div class="parent" style="background-color: lightgrey;">  
  2.     <div class="left" style="background-color: lightblue;">  
  3.         <p>left</p>  
  4.     </div>  
  5.     <div class="right"  style="background-color: lightgreen;">  
  6.         <p>right</p>  
  7.         <p>right</p>  
  8.     </div>           
  9. </div>  

 思路二: table

若table元素不设置table-layout:fixed,则宽度由内容撑开。在某个table-cell元素的外层嵌套一层div,并设置足够小的宽度如width:0.1%

CSS Code复制内容到剪贴板
  1. <style>   
  2. p{margin: 0;}   
  3. .parent{display:table;width:100%;}   
  4. .leftWrap{display:table-cell;width:0.1%;}   
  5. .left{margin-right20px;}       
  6. .rightright{display:table-cell;}   
  7. </style>  

XML/HTML Code复制内容到剪贴板
  1. <div class="parent" style="background-color: lightgrey;">  
  2.     <div class="leftWrap" style="background-color: pink;">  
  3.         <div class="left" style="background-color: lightblue;">  
  4.             <p>left</p>  
  5.         </div>           
  6.     </div>  
  7.     <div class="right"  style="background-color: lightgreen;">  
  8.         <p>right</p>  
  9.         <p>right</p>  
  10.     </div>           
  11. </div>  

思路三: flex

flex弹性盒模型是非常强大的布局方式。基本上,一般的布局方式都可以实现

[注意]IE9-不支持
 

CSS Code复制内容到剪贴板
  1. <style>   
  2. p{margin: 0;}   
  3. .parent{display:flex;}     
  4. .rightright{margin-left:20px; flex:1;}   
  5. </style>  

XML/HTML Code复制内容到剪贴板
  1. <div class="parent" style="background-color: lightgrey;">  
  2.     <div class="left" style="background-color: lightblue;">  
  3.         <p>left</p>  
  4.     </div>           
  5.     <div class="right"  style="background-color: lightgreen;">  
  6.         <p>right</p>  
  7.         <p>right</p>  
  8.     </div>           
  9. </div>  

以上这篇浅析两列自适应布局的3种思路就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

原文地址:http://www.cnblogs.com/xiaohuochai/archive/2016/05/03/5454232.html

相关文章

  • CSS 变形(CSS3 transform)实例详解

    transform是CSS3中具有颠覆性的特征之一,可以实现元素的位移、旋转、倾斜、缩放,甚至支持矩阵方式,配合过渡和即将学习的动画知识,可以取代大量之前只能靠Flash才可以实
    2023-04-27
  • CSS transform属性基础篇

    这篇文章主要介绍了CSS transform属性一些基础知识与介绍,需要的朋友可以参考下
    2023-04-28
  • 36种漂亮的CSS3网页按钮Button样式(主要结合before与after)

    这篇文章主要介绍了36种漂亮的CSS3网页按钮Button样式,主要结合before与after,需要的朋友可以参考下
    2023-03-25
  • css3鼠标滑过实现动画线条边框

    现如今网页越来越趋近于动画,相信大家平时浏览网页或多或少都能看到一些动画效果,今天我们做一个通过 css3 鼠标滑过实现动画线条边框,下面一起看看吧
    2023-02-22
  • CSS3使用双旋转实现福到了的迎春喜庆特效代码

    春节快到了,因为疫情已经好久没有回老家了,今年终于可以回家过年了,我已经抑制不住自己激动的心情了。因此,我利用css3的旋转做了一个福到了的特效,而且是双旋转,感兴
    2023-01-29
  • CSS3实现一根心爱的二踢脚示例代码

    这篇文章主要介绍了CSS3实现一根心爱的二踢脚示例代码,这里主要是布局一个DIV元素,根据现实的二踢脚设置其宽高,并且利用css3的box-shadow属性添加阴影效果,需要的朋友可
    2023-01-05
  • css3手动实现pc端横向滚动

    本文主要介绍了css3手动实现pc端横向滚动,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-20
  • CSS3实现指纹特效代码

    本文通过实例代码介绍了CSS3实现指纹特效,代码简单易懂,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2022-03-16
  • css3新增选择器的应用示例

    这篇文章主要为大家介绍了css3新增选择器的应用示例以及内容解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-10
  • css3新特性的应用示例分析

    这篇文章主要为大家介绍了css3新特性的应用示例分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪
    2022-03-14

最新评论