极乐门资源网 Design By www.ioogu.com

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

思路一: float

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

【1】float + padding + background-clip

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

CSS Code复制内容到剪贴板
  1. <style>   
  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. </style>   
  19.   
XML/HTML Code复制内容到剪贴板
  1. <div class="parentWrap">  
  2.     <div class="parent" style="background-color: lightgrey;">  
  3.         <div class="child" style="background-color: lightblue;">1</div>  
  4.         <div class="child" style="background-color: lightgreen;">2</div>  
  5.         <div class="child" style="background-color: lightsalmon;">3</div>  
  6.         <div class="child" style="background-color: pink;">4</div>                   
  7.     </div>       
  8. </div>  
  9.   

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

【2】float + margin + calc

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

CSS Code复制内容到剪贴板
  1. <style>   
  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. </style>  
XML/HTML Code复制内容到剪贴板
  1. <div class="parentWrap">  
  2.     <div class="parent" style="background-color: lightgrey;">  
  3.         <div class="child" style="background-color: lightblue;">1</div>  
  4.         <div class="child" style="background-color: lightgreen;">2</div>  
  5.         <div class="child" style="background-color: lightsalmon;">3</div>  
  6.         <div class="child" style="background-color: pink;">4</div>                   
  7.     </div>       
  8. </div>  
  9.   

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

【3】float + margin + (fix)

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

CSS Code复制内容到剪贴板
  1. <style>   
  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. </style>   
  19.   
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;">1</div>  
  5.         </div>  
  6.         <div class="child" style="background-color: green;">  
  7.             <div class="in" style="background-color: lightgreen;">2</div>  
  8.         </div>  
  9.         <div class="child" style="background-color: orange;">  
  10.             <div class="in" style="background-color: lightsalmon;">3</div>  
  11.         </div>  
  12.         <div class="child" style="background-color: red;">  
  13.             <div class="in" style="background-color: pink;">4</div>  
  14.         </div>                   
  15.     </div>       
  16. </div>  
  17.   

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.     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. </style>   
  21.   
XML/HTML Code复制内容到剪贴板
  1. <div class="parentWrap">  
  2.     <div class="parent" style="background-color: lightgrey;">  
  3.         <div class="child" style="background-color: lightblue;">1</div>  
  4.         <div class="child" style="background-color: lightgreen;">2</div>  
  5.         <div class="child" style="background-color: lightsalmon;">3</div>  
  6.         <div class="child" style="background-color: pink;">4</div>                   
  7.     </div>       
  8. </div>  
  9.   

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

【2】inline-block + margin + calc

CSS Code复制内容到剪贴板
  1. <style>   
  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. </style>   
  19.   
XML/HTML Code复制内容到剪贴板
  1. <div class="parentWrap">  
  2.     <div class="parent" style="background-color: lightgrey;">  
  3.         <div class="child" style="background-color: lightblue;">1</div>  
  4.         <div class="child" style="background-color: lightgreen;">2</div>  
  5.         <div class="child" style="background-color: lightsalmon;">3</div>  
  6.         <div class="child" style="background-color: pink;">4</div>                   
  7.     </div>       
  8. </div>  
  9.   

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

CSS Code复制内容到剪贴板
  1. <style>   
  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. </style>   
  21.   
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;">1</div>  
  5.         </div>  
  6.         <div class="child" style="background-color: green;">  
  7.             <div class="in" style="background-color: lightgreen;">2</div>  
  8.         </div>  
  9.         <div class="child" style="background-color: orange;">  
  10.             <div class="in" style="background-color: lightsalmon;">3</div>  
  11.         </div>  
  12.         <div class="child" style="background-color: red;">  
  13.             <div class="in" style="background-color: pink;">4</div>  
  14.         </div>                   
  15.     </div>       
  16. </div>  
  17.   

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.     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. </style>   
  17.   
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;">1</div>  
  5.         </div>  
  6.         <div class="child" style="background-color: green;">  
  7.             <div class="in" style="background-color: lightgreen;">2</div>  
  8.         </div>  
  9.         <div class="child" style="background-color: orange;">  
  10.             <div class="in" style="background-color: lightsalmon;">3</div>  
  11.         </div>  
  12.         <div class="child" style="background-color: red;">  
  13.             <div class="in" style="background-color: pink;">4</div>  
  14.         </div>                   
  15.     </div>       
  16. </div>  
  17.     

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


【2】table + 兄弟选择器

CSS Code复制内容到剪贴板
  1. <style>   
  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. </style>   
  16.   
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;">1</div>  
  4.     </div>  
  5.     <div class="child" style="background-color: green;">  
  6.         <div class="in" style="background-color: lightgreen;">2</div>  
  7.     </div>  
  8.     <div class="child" style="background-color: orange;">  
  9.         <div class="in" style="background-color: lightsalmon;">3</div>  
  10.     </div>  
  11.     <div class="child" style="background-color: red;">  
  12.         <div class="in" style="background-color: pink;">4</div>  
  13.     </div>                   
  14. </div>       
  15.     

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

思路四: flex

CSS Code复制内容到剪贴板
  1. <style>   
  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. </style>   
  14.   
XML/HTML Code复制内容到剪贴板
  1. <div class="parent" style="background-color: lightgrey;">  
  2.     <div class="child" style="background-color: lightblue;">1</div>  
  3.     <div class="child" style="background-color: lightgreen;">2</div>  
  4.     <div class="child" style="background-color: lightsalmon;">3</div>  
  5.     <div class="child" style="background-color: pink;">4</div>                   
  6. </div>     
  7.   

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

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

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

标签:
CSS,等分,布局

极乐门资源网 Design By www.ioogu.com
极乐门资源网 免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
极乐门资源网 Design By www.ioogu.com

评论“CSS实现等分布局的4种方式”

暂无CSS实现等分布局的4种方式的评论...

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。