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

来源:爱站网时间:2019-01-28编辑:网友分享
今天爱站技术频道的小编将给小伙伴们讲述CSS实现等分布局的四种方式,等分布局是指子元素平均分配父元素宽度的布局方式,本文将介绍实现等分布局的4种方式,感兴趣的小伙伴们可以参考一下

今天爱站技术频道的小编将给小伙伴们讲述CSS实现等分布局的四种方式,等分布局是指子元素平均分配父元素宽度的布局方式,本文将介绍实现等分布局的4种方式,感兴趣的小伙伴们可以参考一下

思路一: float

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

【1】float + padding + background-clip

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

CSS Code复制内容到剪贴板
  1. body,p{margin: 0;}   
  2. .parentWrap{   
  3.     overflowhidden;   
  4. }   
  5. .parent{   
  6.     margin-right: -20px;   
  7.     overflowhidden;   
  8. }   
  9. .child{   
  10.     floatleft;   
  11.     height100px;   
  12.     width: 25%;   
  13.     padding-right20px;   
  14.     box-sizing: border-box;   
  15.     background-clipcontent-box;   
  16. }   
  17.   
  18.   
XML/HTML Code复制内容到剪贴板
  1. div class="parentWrap">  
  2.     div class="parent" style="background-color: lightgrey;">  
  3.         div class="child" style="background-color: lightblue;">1div>  
  4.         div class="child" style="background-color: lightgreen;">2div>  
  5.         div class="child" style="background-color: lightsalmon;">3div>  
  6.         div class="child" style="background-color: pink;">4div>                   
  7.     div>       
  8. div>  
  9.   

【2】float + margin + calc

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

CSS Code复制内容到剪贴板
  1. body,p{margin: 0;}   
  2. .parentWrap{   
  3.     overflowhidden;   
  4. }   
  5. .parent{   
  6.     overflowhidden;   
  7.     margin-right: -20px;   
  8. }   
  9. .child{   
  10.     floatleft;   
  11.     height100px;   
  12.     width: calc(25% - 20px);   
  13.     margin-right20px;   
  14. }   
  15.   
XML/HTML Code复制内容到剪贴板
  1. div class="parentWrap">  
  2.     div class="parent" style="background-color: lightgrey;">  
  3.         div class="child" style="background-color: lightblue;">1div>  
  4.         div class="child" style="background-color: lightgreen;">2div>  
  5.         div class="child" style="background-color: lightsalmon;">3div>  
  6.         div class="child" style="background-color: pink;">4div>                   
  7.     div>       
  8. div>  
  9.   

【3】float + margin + (fix)

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

CSS Code复制内容到剪贴板
  1. body,p{margin: 0;}   
  2. .parentWrap{   
  3.     overflowhidden;   
  4. }   
  5. .parent{   
  6.     overflowhidden;   
  7.     margin-right: -20px;   
  8. }   
  9. .child{   
  10.     floatleft;   
  11.     width: 25%;   
  12. }   
  13. .in{   
  14.     margin-right20px;   
  15.     height100px;   
  16. }   
  17.   
  18.   
XML/HTML Code复制内容到剪贴板
  1. div class="parentWrap">  
  2.     div class="parent" style="background-color: lightgrey;">  
  3.         div class="child" style="background-color: blue;">  
  4.             div class="in" style="background-color: lightblue;">1div>  
  5.         div>  
  6.         div class="child" style="background-color: green;">  
  7.             div class="in" style="background-color: lightgreen;">2div>  
  8.         div>  
  9.         div class="child" style="background-color: orange;">  
  10.             div class="in" style="background-color: lightsalmon;">3div>  
  11.         div>  
  12.         div class="child" style="background-color: red;">  
  13.             div class="in" style="background-color: pink;">4div>  
  14.         div>                   
  15.     div>       
  16. div>  
  17.   

思路二: inline-block

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

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

CSS Code复制内容到剪贴板
  1. body,p{margin: 0;}   
  2. .parentWrap{   
  3.     overflowhidden;   
  4. }   
  5. .parent{   
  6.     font-size: 0;   
  7.     margin-right: -20px;   
  8.     overflowhidden;   
  9. }   
  10. .child{   
  11.     display:inline-block;   
  12.     vertical-aligntop;   
  13.     width: 25%;   
  14.     padding-right20px;   
  15.     box-sizing: border-box;   
  16.     background-clipcontent-box;   
  17.     font-size16px;   
  18. }   
  19.   
  20.   
XML/HTML Code复制内容到剪贴板
  1. div class="parentWrap">  
  2.     div class="parent" style="background-color: lightgrey;">  
  3.         div class="child" style="background-color: lightblue;">1div>  
  4.         div class="child" style="background-color: lightgreen;">2div>  
  5.         div class="child" style="background-color: lightsalmon;">3div>  
  6.         div class="child" style="background-color: pink;">4div>                   
  7.     div>       
  8. div>  
  9.   

【2】inline-block + margin + calc

CSS Code复制内容到剪贴板
  1. body,p{margin: 0;}   
  2. .parentWrap{   
  3.     overflowhidden;   
  4. }   
  5. .parent{   
  6.     margin-right: -20px;   
  7.     font-size: 0;   
  8. }   
  9. .child{   
  10.     displayinline-block;   
  11.     vertical-aligntop;   
  12.     font-size16px;   
  13.     height100px;   
  14.     width: calc(25% - 20px);   
  15.     margin-right20px;   
  16. }   
  17.   
  18.   
XML/HTML Code复制内容到剪贴板
  1. div class="parentWrap">  
  2.     div class="parent" style="background-color: lightgrey;">  
  3.         div class="child" style="background-color: lightblue;">1div>  
  4.         div class="child" style="background-color: lightgreen;">2div>  
  5.         div class="child" style="background-color: lightsalmon;">3div>  
  6.         div class="child" style="background-color: pink;">4div>                   
  7.     div>       
  8. div>  
  9.   

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

CSS Code复制内容到剪贴板
  1. body,p{margin: 0;}   
  2. .parentWrap{   
  3.     overflowhidden;   
  4. }   
  5. .parent{   
  6.     margin-right: -20px;   
  7.     font-size: 0;   
  8. }   
  9. .child{   
  10.     displayinline-block;   
  11.     vertical-aligntop;   
  12.     font-size16px;   
  13.     width: 25%;   
  14. }   
  15. .in{   
  16.     margin-right20px;   
  17.     height100px;   
  18. }   
  19.   
  20.   
XML/HTML Code复制内容到剪贴板
  1. div class="parentWrap">  
  2.     div class="parent" style="background-color: lightgrey;">  
  3.         div class="child" style="background-color: blue;">  
  4.             div class="in" style="background-color: lightblue;">1div>  
  5.         div>  
  6.         div class="child" style="background-color: green;">  
  7.             div class="in" style="background-color: lightgreen;">2div>  
  8.         div>  
  9.         div class="child" style="background-color: orange;">  
  10.             div class="in" style="background-color: lightsalmon;">3div>  
  11.         div>  
  12.         div class="child" style="background-color: red;">  
  13.             div class="in" style="background-color: pink;">4div>  
  14.         div>                   
  15.     div>       
  16. div>  
  17.   

思路三: table

缺点:元素被设置为table后,内容撑开宽度。若要兼容IE7-浏览器,需要改为结构。table-cell元素无法设置margin,设置padding及background-clip也不可行

 

【1】table + margin负值

CSS Code复制内容到剪贴板
  1. body,p{margin: 0;}   
  2. .parentWrap{   
  3.     overflowhidden;   
  4. }   
  5. .parent{   
  6.     display: table;   
  7.     width: calc(100% + 20px);   
  8.     table-layoutfixed;   
  9. }   
  10. .child{   
  11.     displaytable-cell;   
  12.     height100px;   
  13.     padding-right20px;   
  14. }   
  15.   
  16.   
XML/HTML Code复制内容到剪贴板
  1. div class="parentWrap">  
  2.     div class="parent" style="background-color: lightgrey;">  
  3.         div class="child" style="background-color: blue;">  
  4.             div class="in" style="background-color: lightblue;">1div>  
  5.         div>  
  6.         div class="child" style="background-color: green;">  
  7.             div class="in" style="background-color: lightgreen;">2div>  
  8.         div>  
  9.         div class="child" style="background-color: orange;">  
  10.             div class="in" style="background-color: lightsalmon;">3div>  
  11.         div>  
  12.         div class="child" style="background-color: red;">  
  13.             div class="in" style="background-color: pink;">4div>  
  14.         div>                   
  15.     div>       
  16. div>  
  17.     


【2】table + 兄弟选择器

CSS Code复制内容到剪贴板
  1. body,p{margin: 0;}   
  2. .parent{   
  3.     display: table;   
  4.     width: 100%;   
  5.     table-layoutfixed;   
  6. }   
  7. .child{   
  8.     displaytable-cell;   
  9.     height100px;   
  10. }   
  11. .child + .child{   
  12.     padding-left20px;   
  13. }   
  14.   
  15.   
XML/HTML Code复制内容到剪贴板
  1. div class="parent" style="background-color: lightgrey;">  
  2.     div class="child" style="background-color: blue;">  
  3.         div class="in" style="background-color: lightblue;">1div>  
  4.     div>  
  5.     div class="child" style="background-color: green;">  
  6.         div class="in" style="background-color: lightgreen;">2div>  
  7.     div>  
  8.     div class="child" style="background-color: orange;">  
  9.         div class="in" style="background-color: lightsalmon;">3div>  
  10.     div>  
  11.     div class="child" style="background-color: red;">  
  12.         div class="in" style="background-color: pink;">4div>  
  13.     div>                   
  14. div>       
  15.     

思路四: flex

CSS Code复制内容到剪贴板
  1. body,p{margin: 0;}   
  2. .parent{   
  3.     display: flex;   
  4. }   
  5. .child{   
  6.     flex:1;   
  7.     height100px;   
  8. }   
  9. .child + .child{   
  10.     margin-left20px;   
  11. }   
  12.   
  13.   
XML/HTML Code复制内容到剪贴板
  1. div class="parent" style="background-color: lightgrey;">  
  2.     div class="child" style="background-color: lightblue;">1div>  
  3.     div class="child" style="background-color: lightgreen;">2div>  
  4.     div class="child" style="background-color: lightsalmon;">3div>  
  5.     div class="child" style="background-color: pink;">4div>                   
  6. div>     
  7.   

 以上就是CSS实现等分布局的四种方式的全部内容,希望对大家的学习有所帮助,更多关于CSS的内容,请继续关注爱站技术频道。

上一篇:详解CSS 动画技巧与细节

下一篇:CSS中height和min-height的差异

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载