栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Html/CSS > CSS教程

CSS实现等分布局的4种方式

CSS教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

等分布局是指子元素平均分配父元素宽度的布局方式,本文将介绍实现等分布局的4种方式

思路一: float

缺点:结构和样式存在耦合性,IE7-浏览器下对宽度百分比取值存在四舍五入的误差

【1】float + padding + background-clip

使用padding来实现子元素之间的间距,使用background-clip使子元素padding部分不显示背景

CSS Code复制内容到剪贴板
  1.   
  2. body,p{margin: 0;}   
  3. .parentWrap{   
  4.     overflow: hidden;   
  5. }   
  6. .parent{   
  7.     margin-right: -20px;   
  8.     overflow: hidden;   
  9. }   
  10. .child{   
  11.     float: left;   
  12.     height: 100px;   
  13.     width: 25%;   
  14.     padding-right: 20px;   
  15.     box-sizing: border-box;   
  16.     background-clip: content-box;   
  17. }   
  18.   
  19.   
XML/HTML Code复制内容到剪贴板
  1.   
  2.       
  3.         1
  
  •         2
  •   
  •         3
  •   
  •         4
  •                    
  •            
  •   
  •   
  • 【2】float + margin + calc

    使用margin实现子元素之间的间距,使用calc()函数计算子元素的宽度

    CSS Code复制内容到剪贴板
    1.   
    2. body,p{margin: 0;}   
    3. .parentWrap{   
    4.     overflow: hidden;   
    5. }   
    6. .parent{   
    7.     overflow: hidden;   
    8.     margin-right: -20px;   
    9. }   
    10. .child{   
    11.     float: left;   
    12.     height: 100px;   
    13.     width: calc(25% - 20px);   
    14.     margin-right: 20px;   
    15. }   
    16.   
    XML/HTML Code复制内容到剪贴板
    1.   
    2.       
    3.         1  
    4.         2  
    5.         3  
    6.         4                   
    7.            
    8.   
    9.   

    【3】float + margin + (fix)

    使用margin实现子元素之间的间距,通过增加结构来实现兼容

    CSS Code复制内容到剪贴板
    1.   
    2. body,p{margin: 0;}   
    3. .parentWrap{   
    4.     overflow: hidden;   
    5. }   
    6. .parent{   
    7.     overflow: hidden;   
    8.     margin-right: -20px;   
    9. }   
    10. .child{   
    11.     float: left;   
    12.     width: 25%;   
    13. }   
    14. .in{   
    15.     margin-right: 20px;   
    16.     height: 100px;   
    17. }   
    18.   
    19.   
    XML/HTML Code复制内容到剪贴板
    1.   
    2.       
    3.           
    4.             1  
    5.           
    6.           
    7.             2  
    8.           
    9.           
    10.             3  
    11.           
    12.           
    13.             4  
    14.                            
    15.            
    16.   
    17.   

    思路二: inline-block

    缺点:需要设置垂直对齐方式vertical-align,则需要处理换行符解析成空格的间隙问题。IE7-浏览器不支持给块级元素设置inline-block属性,兼容代码是display:inline;zoom:1;

    【1】inline-block + padding + background-clip

    CSS Code复制内容到剪贴板
    1.   
    2. body,p{margin: 0;}   
    3. .parentWrap{   
    4.     overflow: hidden;   
    5. }   
    6. .parent{   
    7.     font-size: 0;   
    8.     margin-right: -20px;   
    9.     overflow: hidden;   
    10. }   
    11. .child{   
    12.     display:inline-block;   
    13.     vertical-align: top;   
    14.     width: 25%;   
    15.     padding-right: 20px;   
    16.     box-sizing: border-box;   
    17.     background-clip: content-box;   
    18.     font-size: 16px;   
    19. }   
    20.   
    21.   
    XML/HTML Code复制内容到剪贴板
    1.   
    2.       
    3.         1  
    4.         2  
    5.         3  
    6.         4                   
    7.            
    8.   
    9.   

    【2】inline-block + margin + calc

    CSS Code复制内容到剪贴板
    1.   
    2. body,p{margin: 0;}   
    3. .parentWrap{   
    4.     overflow: hidden;   
    5. }   
    6. .parent{   
    7.     margin-right: -20px;   
    8.     font-size: 0;   
    9. }   
    10. .child{   
    11.     display: inline-block;   
    12.     vertical-align: top;   
    13.     font-size: 16px;   
    14.     height: 100px;   
    15.     width: calc(25% - 20px);   
    16.     margin-right: 20px;   
    17. }   
    18.   
    19.   
    XML/HTML Code复制内容到剪贴板
    1.   
    2.       
    3.         1  
    4.         2  
    5.         3  
    6.         4                   
    7.            
    8.   
    9.   

     【3】inline-block + margin + (fix)

    CSS Code复制内容到剪贴板
    1.   
    2. body,p{margin: 0;}   
    3. .parentWrap{   
    4.     overflow: hidden;   
    5. }   
    6. .parent{   
    7.     margin-right: -20px;   
    8.     font-size: 0;   
    9. }   
    10. .child{   
    11.     display: inline-block;   
    12.     vertical-align: top;   
    13.     font-size: 16px;   
    14.     width: 25%;   
    15. }   
    16. .in{   
    17.     margin-right: 20px;   
    18.     height: 100px;   
    19. }   
    20.   
    21.   
    XML/HTML Code复制内容到剪贴板
    1.   
    2.       
    3.           
    4.             1  
    5.           
    6.           
    7.             2  
    8.           
    9.           
    10.             3  
    11.           
    12.           
    13.             4  
    14.                            
    15.            
    16.   
    17.   

    思路三: table

    缺点:元素被设置为table后,内容撑开宽度。若要兼容IE7-浏览器,需要改为

    结构。table-cell元素无法设置margin,设置padding及background-clip也不可行

    【1】table + margin负值

    CSS Code复制内容到剪贴板
    1.   
    2. body,p{margin: 0;}   
    3. .parentWrap{   
    4.     overflow: hidden;   
    5. }   
    6. .parent{   
    7.     display: table;   
    8.     width: calc(100% + 20px);   
    9.     table-layout: fixed;   
    10. }   
    11. .child{   
    12.     display: table-cell;   
    13.     height: 100px;   
    14.     padding-right: 20px;   
    15. }   
    16.   
    17.   
    XML/HTML Code复制内容到剪贴板
    1.   
    2.       
    3.           
    4.             1  
    5.           
    6.           
    7.             2  
    8.           
    9.           
    10.             3  
    11.           
    12.           
    13.             4  
    14.                            
    15.            
    16.   
    17.     


    【2】table + 兄弟选择器

    CSS Code复制内容到剪贴板
    1.   
    2. body,p{margin: 0;}   
    3. .parent{   
    4.     display: table;   
    5.     width: 100%;   
    6.     table-layout: fixed;   
    7. }   
    8. .child{   
    9.     display: table-cell;   
    10.     height: 100px;   
    11. }   
    12. .child + .child{   
    13.     padding-left: 20px;   
    14. }   
    15.   
    16.   
    XML/HTML Code复制内容到剪贴板
    1.   
    2.       
    3.         1  
    4.       
    5.       
    6.         2  
    7.       
    8.       
    9.         3  
    10.       
    11.       
    12.         4  
    13.                        
    14.        
    15.     

    思路四: flex

    CSS Code复制内容到剪贴板
    1.   
    2. body,p{margin: 0;}   
    3. .parent{   
    4.     display: flex;   
    5. }   
    6. .child{   
    7.     flex:1;   
    8.     height: 100px;   
    9. }   
    10. .child + .child{   
    11.     margin-left: 20px;   
    12. }   
    13.   
    14.   
    XML/HTML Code复制内容到剪贴板
    1.   
    2.     1  
    3.     2  
    4.     3  
    5.     4                   
    6.      
    7.   

     以上就是本文的全部内容,希望对大家的学习有所帮助。

    本文链接:http://www.cnblogs.com/xiaohuochai/p/5456695.html

    转载请注明:文章转载自 www.mshxw.com
    本文地址:https://www.mshxw.com/it/217660.html

    CSS教程相关栏目本月热门文章

    我们一直用心在做
    关于我们 文章归档 网站地图 联系我们

    版权所有 (c)2021-2022 MSHXW.COM

    ICP备案号:晋ICP备2021003244-6号