当前位置:Web前端 > > 正文

css三种布局模式(CSS实现等分布局的4种方式)

时间:2021-11-08 16:12:29类别:Web前端

css三种布局模式

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

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

思路一: float

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

【1】float + padding + background-clip

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

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. body,p{margin: 0;}   
    3. .parentWrap{   
    4.     overflowhidden;   
    5. }   
    6. .parent{   
    7.     margin-right: -20px;   
    8.     overflowhidden;   
    9. }   
    10. .child{   
    11.     floatleft;   
    12.     height100px;   
    13.     width: 25%;   
    14.     padding-right20px;   
    15.     box-sizing: border-box;   
    16.     background-clipcontent-box;   
    17. }   
    18. </style>   
    19.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parentWrap">  
    2.     <li class="parent" style="background-color: lightgrey;">  
    3.         <li class="child" style="background-color: lightblue;">1</li>  
    4.         <li class="child" style="background-color: lightgreen;">2</li>  
    5.         <li class="child" style="background-color: lightsalmon;">3</li>  
    6.         <li class="child" style="background-color: pink;">4</li>                   
    7.     </li>       
    8. </li>  
    9.   
  • css三种布局模式(CSS实现等分布局的4种方式)

    【2】float + margin + calc

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

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. body,p{margin: 0;}   
    3. .parentWrap{   
    4.     overflowhidden;   
    5. }   
    6. .parent{   
    7.     overflowhidden;   
    8.     margin-right: -20px;   
    9. }   
    10. .child{   
    11.     floatleft;   
    12.     height100px;   
    13.     width: calc(25% - 20px);   
    14.     margin-right20px;   
    15. }   
    16. </style>  
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parentWrap">  
    2.     <li class="parent" style="background-color: lightgrey;">  
    3.         <li class="child" style="background-color: lightblue;">1</li>  
    4.         <li class="child" style="background-color: lightgreen;">2</li>  
    5.         <li class="child" style="background-color: lightsalmon;">3</li>  
    6.         <li class="child" style="background-color: pink;">4</li>                   
    7.     </li>       
    8. </li>  
    9.   
  • css三种布局模式(CSS实现等分布局的4种方式)

    【3】float + margin + (fix)

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

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. body,p{margin: 0;}   
    3. .parentWrap{   
    4.     overflowhidden;   
    5. }   
    6. .parent{   
    7.     overflowhidden;   
    8.     margin-right: -20px;   
    9. }   
    10. .child{   
    11.     floatleft;   
    12.     width: 25%;   
    13. }   
    14. .in{   
    15.     margin-right20px;   
    16.     height100px;   
    17. }   
    18. </style>   
    19.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parentWrap">  
    2.     <li class="parent" style="background-color: lightgrey;">  
    3.         <li class="child" style="background-color: blue;">  
    4.             <li class="in" style="background-color: lightblue;">1</li>  
    5.         </li>  
    6.         <li class="child" style="background-color: green;">  
    7.             <li class="in" style="background-color: lightgreen;">2</li>  
    8.         </li>  
    9.         <li class="child" style="background-color: orange;">  
    10.             <li class="in" style="background-color: lightsalmon;">3</li>  
    11.         </li>  
    12.         <li class="child" style="background-color: red;">  
    13.             <li class="in" style="background-color: pink;">4</li>  
    14.         </li>                   
    15.     </li>       
    16. </li>  
    17.   
  • css三种布局模式(CSS实现等分布局的4种方式)

    思路二: inline-block

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

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

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. body,p{margin: 0;}   
    3. .parentWrap{   
    4.     overflowhidden;   
    5. }   
    6. .parent{   
    7.     font-size: 0;   
    8.     margin-right: -20px;   
    9.     overflowhidden;   
    10. }   
    11. .child{   
    12.     display:inline-block;   
    13.     vertical-aligntop;   
    14.     width: 25%;   
    15.     padding-right20px;   
    16.     box-sizing: border-box;   
    17.     background-clipcontent-box;   
    18.     font-size16px;   
    19. }   
    20. </style>   
    21.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parentWrap">  
    2.     <li class="parent" style="background-color: lightgrey;">  
    3.         <li class="child" style="background-color: lightblue;">1</li>  
    4.         <li class="child" style="background-color: lightgreen;">2</li>  
    5.         <li class="child" style="background-color: lightsalmon;">3</li>  
    6.         <li class="child" style="background-color: pink;">4</li>                   
    7.     </li>       
    8. </li>  
    9.   
  • css三种布局模式(CSS实现等分布局的4种方式)

    【2】inline-block + margin + calc

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

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. body,p{margin: 0;}   
    3. .parentWrap{   
    4.     overflowhidden;   
    5. }   
    6. .parent{   
    7.     margin-right: -20px;   
    8.     font-size: 0;   
    9. }   
    10. .child{   
    11.     displayinline-block;   
    12.     vertical-aligntop;   
    13.     font-size16px;   
    14.     width: 25%;   
    15. }   
    16. .in{   
    17.     margin-right20px;   
    18.     height100px;   
    19. }   
    20. </style>   
    21.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parentWrap">  
    2.     <li class="parent" style="background-color: lightgrey;">  
    3.         <li class="child" style="background-color: blue;">  
    4.             <li class="in" style="background-color: lightblue;">1</li>  
    5.         </li>  
    6.         <li class="child" style="background-color: green;">  
    7.             <li class="in" style="background-color: lightgreen;">2</li>  
    8.         </li>  
    9.         <li class="child" style="background-color: orange;">  
    10.             <li class="in" style="background-color: lightsalmon;">3</li>  
    11.         </li>  
    12.         <li class="child" style="background-color: red;">  
    13.             <li class="in" style="background-color: pink;">4</li>  
    14.         </li>                   
    15.     </li>       
    16. </li>  
    17.   
  • css三种布局模式(CSS实现等分布局的4种方式)

    思路三: table

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

    【1】table + margin负值

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

    【2】table + 兄弟选择器

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. body,p{margin: 0;}   
    3. .parent{   
    4.     display: table;   
    5.     width: 100%;   
    6.     table-layoutfixed;   
    7. }   
    8. .child{   
    9.     displaytable-cell;   
    10.     height100px;   
    11. }   
    12. .child + .child{   
    13.     padding-left20px;   
    14. }   
    15. </style>   
    16.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parent" style="background-color: lightgrey;">  
    2.     <li class="child" style="background-color: blue;">  
    3.         <li class="in" style="background-color: lightblue;">1</li>  
    4.     </li>  
    5.     <li class="child" style="background-color: green;">  
    6.         <li class="in" style="background-color: lightgreen;">2</li>  
    7.     </li>  
    8.     <li class="child" style="background-color: orange;">  
    9.         <li class="in" style="background-color: lightsalmon;">3</li>  
    10.     </li>  
    11.     <li class="child" style="background-color: red;">  
    12.         <li class="in" style="background-color: pink;">4</li>  
    13.     </li>                   
    14. </li>       
    15.     
  • css三种布局模式(CSS实现等分布局的4种方式)

    思路四: flex

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

    猜您喜欢

    热门推荐