1、技术点
移动端自适应采用百分比布局比较适合。需要说明一点的是:height的百分比是以父元素的宽度计算的,由于移动端父元素宽度有时没有给定值(如父元素宽度为100%),此时子元素的height就为0。
因此子元素的高度值使用padding-top或者padding-bottom撑起。
同时height的高度设置为0,防止font-size或line-height等属性影响到height。
2、示例
示例为展示图片,每行展示3个图片。每列图片宽度33%,图片间距为0.5%。
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=0">
<meta name="author" content="Tencent-TGideas" />
<meta name="Copyright" content="Tencent" />
<title>实例-图片列表</title>
<style>
* {
margin: 0;
padding: 0;
}
ol,
ul {
list-style: none;
}
html,
body {
position: relative;
width: 100%;
}
h1 {
font-size: 14px;
text-align: center;
line-height: 70px;
}
.lists {
width: 100%;
}
.lists li {
position: relative;
float: left;
width: 33%;
/*高度设置为0*/
height: 0;
/*padding-bottom设置为33% 以撑起高度*/
padding: 0 0 33%;
margin-top: .5%
}
.lists li:nth-child(3n-1) {
/*图片间距*/
margin: .5% .5% 0;
}
.lists li a,
.lists li img {
width: 100%;
height: 100%;
}
.lists li a {
position: absolute;
top: 0;
left: 0;
}
</style>
</head>
<body>
<h1>图片列表</h1>
<ul class="lists">
<li>
<a href="javascript:alert('图片');"><img src="img/sqbg-icon.png" alt="图片"></a>
</li>
<li>
<a href="javascript:alert('图片');"><img src="img/sqbg-icon.png" alt="图片"></a>
</li>
<li>
<a href="javascript:alert('图片');"><img src="img/sqbg-icon.png" alt="图片"></a>
</li>
<li>
<a href="javascript:alert('图片');"><img src="img/sqbg-icon.png" alt="图片"></a>
</li>
<li>
<a href="javascript:alert('图片');"><img src="img/sqbg-icon.png" alt="图片"></a>
</li>
<li>
<a href="javascript:alert('图片');"><img src="img/sqbg-icon.png" alt="图片"></a>
</li>
<li>
<a href="javascript:alert('图片');"><img src="img/sqbg-icon.png" alt="图片"></a>
</li>
<li>
<a href="javascript:alert('图片');"><img src="img/sqbg-icon.png" alt="图片"></a>
</li>
</ul>
</body>
</html>
效果:

来源:https://www.cnblogs.com/mengfangui/p/7814821.html