博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
php css布局技巧,CSS实现等分布局的4种方式
阅读量:5223 次
发布时间:2019-06-14

本文共 2954 字,大约阅读时间需要 9 分钟。

这篇文章主要为大家详细介绍了CSS实现等分布局的4种方式,等分布局是指子元素平均分配父元素宽度的布局方式,本文将介绍实现等分布局的4种方式,感兴趣的小伙伴们可以参考一下

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

思路一: float

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

【1】float + padding + background-clip

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

CSS Code复制内容到剪贴板

body,p{margin: 0;}

.parentWrap{

overflow: hidden;

}

.parent{

margin-right: -20px;

overflow: hidden;

}

.child{

float: left;

height: 100px;

width: 25%;

box-sizing: border-box;

background-clip: content-box;

}

XML/HTML Code复制内容到剪贴板

1

2

3

4

f37557467358e9e6bfd3061a4f90bd2b.png

【2】float + margin + calc

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

CSS Code复制内容到剪贴板

body,p{margin: 0;}

.parentWrap{

overflow: hidden;

}

.parent{

overflow: hidden;

margin-right: -20px;

}

.child{

float: left;

height: 100px;

width: calc(25% - 20px);

margin-right: 20px;

}

XML/HTML Code复制内容到剪贴板

1

2

3

4

f37557467358e9e6bfd3061a4f90bd2b.png

【3】float + margin + (fix)

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

CSS Code复制内容到剪贴板

body,p{margin: 0;}

.parentWrap{

overflow: hidden;

}

.parent{

overflow: hidden;

margin-right: -20px;

}

.child{

float: left;

width: 25%;

}

.in{

margin-right: 20px;

height: 100px;

}

XML/HTML Code复制内容到剪贴板

1

2

3

4

f90aca6d64a5c99b02dda5b6981bcbb1.png

思路二: inline-block

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

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

CSS Code复制内容到剪贴板

body,p{margin: 0;}

.parentWrap{

overflow: hidden;

}

.parent{

font-size: 0;

margin-right: -20px;

overflow: hidden;

}

.child{

display:inline-block;

vertical-align: top;

width: 25%;

padding-right: 20px;

box-sizing: border-box;

background-clip: content-box;

font-size: 16px;

}

XML/HTML Code复制内容到剪贴板

1

2

3

4

f37557467358e9e6bfd3061a4f90bd2b.png

【2】inline-block + margin + calc

CSS Code复制内容到剪贴板

body,p{margin: 0;}

.parentWrap{

overflow: hidden;

}

.parent{

margin-right: -20px;

font-size: 0;

}

.child{

display: inline-block;

vertical-align: top;

font-size: 16px;

height: 100px;

width: calc(25% - 20px);

margin-right: 20px;

}

XML/HTML Code复制内容到剪贴板

1

2

3

4

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

CSS Code复制内容到剪贴板

body,p{margin: 0;}

.parentWrap{

overflow: hidden;

}

.parent{

margin-right: -20px;

font-size: 0;

}

.child{

display: inline-block;

vertical-align: top;

font-size: 16px;

width: 25%;

}

.in{

margin-right: 20px;

height: 100px;

}

XML/HTML Code复制内容到剪贴板

1

2

3

4

f90aca6d64a5c99b02dda5b6981bcbb1.png

思路三: table

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

【1】table + margin负值

CSS Code复制内容到剪贴板

body,p{margin: 0;}

.parentWrap{

overflow: hidden;

}

.parent{

display: table;

width: calc(100% + 20px);

}

.child{

display: table-cell;

height: 100px;

padding-right: 20px;

}

XML/HTML Code复制内容到剪贴板

1

2

3

4

bdc580ee23649018820cd5753463cc8a.png

【2】table + 兄弟选择器

CSS Code复制内容到剪贴板

body,p{margin: 0;}

.parent{

display: table;

width: 100%;

table-layout: fixed;

}

.child{

display: table-cell;

height: 100px;

}

.child + .child{

}

XML/HTML Code复制内容到剪贴板

1

2

3

4

bdc580ee23649018820cd5753463cc8a.png

思路四: flex

CSS Code复制内容到剪贴板

body,p{margin: 0;}

.parent{

display: flex;

}

.child{

flex:1;

height: 100px;

}

.child + .child{

margin-left: 20px;

}

XML/HTML Code复制内容到剪贴板

1

2

3

4

f37557467358e9e6bfd3061a4f90bd2b.png

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

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

你可能感兴趣的文章
《代码阅读方法与实现》阅读笔记一
查看>>
解决 sublime text3 运行python文件无法input的问题
查看>>
javascript面相对象编程,封装与继承
查看>>
Atlas命名空间Sys.Data下控件介绍——DataColumn,DataRow和DataTable
查看>>
Java中正则表达式的使用
查看>>
算法之搜索篇
查看>>
新的开始
查看>>
java Facade模式
查看>>
NYOJ 120校园网络(有向图的强连通分量)(Kosaraju算法)
查看>>
SpringAop与AspectJ
查看>>
Leetcode 226: Invert Binary Tree
查看>>
http站点转https站点教程
查看>>
解决miner.start() 返回null
查看>>
关于MFC中窗口的销毁
查看>>
bzoj 2007: [Noi2010]海拔【最小割+dijskstra】
查看>>
BZOJ 1001--[BeiJing2006]狼抓兔子(最短路&对偶图)
查看>>
C# Dynamic通用反序列化Json类型并遍历属性比较
查看>>
128 Longest Consecutive Sequence 一个无序整数数组中找到最长连续序列
查看>>
定制jackson的自定义序列化(null值的处理)
查看>>
auth模块
查看>>