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

css三栏布局详解(CSS三列布局的多种表现形式)

时间:2021-11-08 16:19:59类别:Web前端

css三栏布局详解

CSS三列布局的多种表现形式

一、两侧定宽中间自适应布局

思路一:  float

【1】float + margin + calc

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. p{margin: 0;}   
    3. .parent{overflowhidden;}   
    4. .left,.rightright{floatleft;width100px;}   
    5. .center{floatleftwidth:calc(100% - 240px);margin: 0 20px;}   
    6. </style>   
    7.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parent" style="background-color: lightgrey;">  
    2.     <li class="left" style="background-color: lightblue;">  
    3.         <p>left</p>  
    4.     </li>       
    5.     <li class="center" style="background-color: pink;">  
    6.         <p>center</p>  
    7.         <p>center</p>  
    8.     </li>       
    9.     <li class="right"  style="background-color: lightgreen;">  
    10.         <p>right</p>  
    11.     </li>           
    12. </li>  
    13.   
  • css三栏布局详解(CSS三列布局的多种表现形式)

    【2】float + margin + (fix)

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. p{margin: 0;}   
    3. .parent{overflowhidden;}   
    4. .left,.rightright{positionrelative;floatleft;width100px;}   
    5. .centerWrap{floatleftwidth:100%; margin: 0 -100px;}   
    6. .center{margin: 0 120px;}   
    7. </style>   
    8.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parent" style="background-color: lightgrey;">  
    2.     <li class="left" style="background-color: lightblue;">  
    3.         <p>left</p>  
    4.     </li>               
    5.     <li class="centerWrap" style="background-color: red;">  
    6.         <li class="center" style="background-color: pink;">  
    7.             <p>center</p>  
    8.             <p>center</p>  
    9.         </li>           
    10.     </li>  
    11.     <li class="right"  style="background-color: lightgreen;">  
    12.         <p>right</p>  
    13.     </li>               
    14. </li>  
    15.     
  • css三栏布局详解(CSS三列布局的多种表现形式)

    思路二: inline-block

    【1】inline-block + margin + calc

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. p{margin: 0;}   
    3. .parent{font-size: 0;}   
    4. .left,.rightright,.center{display:inline-blockvertical-aligntop;font-size16px;}   
    5. .left,.rightright{width100px;}   
    6. .center{width: calc(100% - 240px); margin: 0 20px;}   
    7. </style>   
    8.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parent" style="background-color: lightgrey;">  
    2.     <li class="left" style="background-color: lightblue;">  
    3.         <p>left</p>  
    4.     </li>               
    5.     <li class="center" style="background-color: pink;">  
    6.         <p>center</p>  
    7.         <p>center</p>  
    8.     </li>           
    9.     <li class="right"  style="background-color: lightgreen;">  
    10.         <p>right</p>  
    11.     </li>               
    12. </li>  
    13.   
  • css三栏布局详解(CSS三列布局的多种表现形式)

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

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. p{margin: 0;}   
    3. .parent{font-size: 0;}   
    4. .left,.rightright,.centerWrap{display:inline-blockvertical-aligntop;font-size16px;}   
    5. .left,.rightright{width100px;position:relative;}   
    6. .centerWrap{width: 100%; margin: 0 -100px;}   
    7. .center{margin: 0 120px;}   
    8. </style>   
    9.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parent" style="background-color: lightgrey;">  
    2.     <li class="left" style="background-color: lightblue;">  
    3.         <p>left</p>  
    4.     </li>       
    5.     <li class="centerWrap" style="background-color: orange;">  
    6.         <li class="center" style="background-color: pink;">  
    7.             <p>center</p>  
    8.             <p>center</p>  
    9.         </li>           
    10.     </li>           
    11.     <li class="right"  style="background-color: lightgreen;">  
    12.         <p>right</p>  
    13.     </li>               
    14. </li>  
    15.   
  •  css三栏布局详解(CSS三列布局的多种表现形式)

    思路三: table

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. p{margin: 0;}   
    3. .parent{display: table; width: 100%;table-layoutfixed;}   
    4. .left,.rightright,.centerWrap{display:table-cell;}   
    5. .left,.rightright{width100px;}   
    6. .center{margin: 0 20px;}   
    7. </style>   
    8.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parent" style="background-color: lightgrey;">  
    2.     <li class="left" style="background-color: lightblue;">  
    3.         <p>left</p>  
    4.     </li>       
    5.     <li class="centerWrap" style="background-color: orange;">  
    6.         <li class="center" style="background-color: pink;">  
    7.             <p>center</p>  
    8.             <p>center</p>  
    9.         </li>           
    10.     </li>           
    11.     <li class="right"  style="background-color: lightgreen;">  
    12.         <p>right</p>  
    13.     </li>               
    14. </li>  
    15.   
  •  css三栏布局详解(CSS三列布局的多种表现形式)

    思路四: absolute

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. p{margin: 0;}   
    3. .parent{positionrelative;height:40px;}   
    4. .left,.rightright,.center{positionabsolute;}   
    5. .left{left: 0;width:100px;}   
    6. .rightright{rightright: 0;width100px;}   
    7. .center{left120pxrightright120px;}   
    8. </style>   
    9.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parent" style="background-color: lightgrey;">  
    2.     <li class="left" style="background-color: lightblue;">  
    3.         <p>left</p>  
    4.     </li>       
    5.     <li class="center" style="background-color: pink;">  
    6.         <p>center</p>  
    7.         <p>center</p>  
    8.     </li>                   
    9.     <li class="right"  style="background-color: lightgreen;">  
    10.         <p>right</p>  
    11.     </li>               
    12. </li>  
  •  css三栏布局详解(CSS三列布局的多种表现形式)

    思路五: flex

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. p{margin: 0;}   
    3. .parent{display: flex;}   
    4. .left,.rightright{width100px;}   
    5. .center{flex: 1; margin: 0 20px;}   
    6. </style>   
    7.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parent" style="background-color: lightgrey;">  
    2.     <li class="left" style="background-color: lightblue;">  
    3.         <p>left</p>  
    4.     </li>       
    5.     <li class="center" style="background-color: pink;">  
    6.         <p>center</p>  
    7.         <p>center</p>  
    8.     </li>                   
    9.     <li class="right"  style="background-color: lightgreen;">  
    10.         <p>right</p>  
    11.     </li>               
    12. </li>  
    13.   
  •  css三栏布局详解(CSS三列布局的多种表现形式)

    二、两列定宽一侧自适应布局

    这种布局与单列定宽单列自适应布局非常相似

    思路一: float

    【1】float + margin

    缺点是IE6-浏览器的3px的bug,以及当自适应列中有元素清除浮动时,会使该元素不与左侧浮动元素同行,从而出现文字下沉现象

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. p{margin: 0;}   
    3. .parent{overflowhidden;}   
    4. .left,.center{floatleft;width100px;margin-right20px;}   
    5. .rightright{margin-left240px;}   
    6. </style>   
    7.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parent" style="background-color: lightgrey;">  
    2.     <li class="left" style="background-color: lightblue;">  
    3.         <p>left</p>  
    4.     </li>       
    5.     <li class="center" style="background-color: pink;">  
    6.         <p>center</p>  
    7.     </li>                   
    8.     <li class="right"  style="background-color: lightgreen;">  
    9.         <p>right</p>  
    10.         <p>right</p>  
    11.     </li>               
    12. </li>  
    13.   
  •  css三栏布局详解(CSS三列布局的多种表现形式)

    【2】float + margin + calc

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. p{margin: 0;}   
    3. .parent{overflowhidden;}   
    4. .left,.center{floatleft;width100px;margin-right20px;}   
    5. .rightright{floatleftwidth: calc(100% - 240px);}   
    6. </style>   
    7.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parent" style="background-color: lightgrey;">  
    2.     <li class="left" style="background-color: lightblue;">  
    3.         <p>left</p>  
    4.     </li>       
    5.     <li class="center" style="background-color: pink;">  
    6.         <p>center</p>  
    7.     </li>                   
    8.     <li class="right"  style="background-color: lightgreen;">  
    9.         <p>right</p>  
    10.         <p>right</p>  
    11.     </li>               
    12. </li>  
    13.   
  •  css三栏布局详解(CSS三列布局的多种表现形式)

    【3】float + margin + (fix)

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. p{margin: 0;}   
    3. .parent{overflowhidden;}   
    4. .left,.center{positionrelativefloatleft;width100px;margin-right20px;}   
    5. .rightWrap{floatleftwidth: 100%; margin-left: -240px;}   
    6. .rightright{margin-left:240px;}   
    7. </style>   
    8.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class="parent" style="background-color: lightgrey;">  
    2.     <li class="left" style="background-color: lightblue;">  
    3.         <p>left</p>  
    4.     </li>       
    5.     <li class="center" style="background-color: pink;">  
    6.         <p>center</p>  
    7.     </li>           
    8.     <li class="rightWrap">  
    9.         <li class="right"  style="background-color: lightgreen;">  
    10.             <p>right</p>  
    11.             <p>right</p>  
    12.         </li>               
    13.     </li>               
    14. </li>  
    15.   
  •  css三栏布局详解(CSS三列布局的多种表现形式)

    【4】float + overflow

  • CSS Code复制内容到剪贴板
    1. <style>   
    2. p{margin: 0;}   
    3. .parent{overflowhidden;}   
    4. .left,.center{positionrelativefloatleft;width100px;margin-right20px;}   
    5. .rightright{overflowhidden;zoom:1;}   
    6. </style>   
    7.   
  • XML/HTML Code复制内容到剪贴板
    1. <li class=标签:
  • 上一篇下一篇

    猜您喜欢

    热门推荐