朋友圈、微博的图片展示会根据数量不同而样式不同,这也可以用纯css实现。在《css揭秘》中,根据兄弟元素的数量来设置样式讲到的技巧就可以解决这个问题。
我们知道css中有一些跟子元素排序相关的伪类选择器,例如,
:nth-child(n) — 匹配属于其父元素的第n个子元素
:nth-last-child(n) — 匹配属于其父元素的倒数第n个子元素
:only-child — 匹配属于其父元素的唯一一个子元素,等价于:nth-child(1):nth-last-child(1)
这些选择器单用很容易理解,其实,可以把它们联合起来,用以更精确定位元素。
在下面这个例子中,img:nth-child(2):nth-last-child(3)表示定位正向数排第二、倒向数排第三的img元素,也就是,只有总数为4,且正向排第二的元素满足条件。将这个元素的margin-right调大,就能将4张图情况下第三张图 “挤” 到下一排,实现四张图的四方格排列。img:only-child表示只有一张图的情况,这个时候要按照图片的横竖比例显示,因此图片不能设置height和width,而是用max-height max-width限制图片的高/宽最大值。
天气真好!
CSS代码
.album{
margin-left: 50px;
width: 342px;
}
img{
height: 110px;
width: 110px;
}
img:only-child{
height: initial; /*相当于删除已设置的某一属性*/
width: initial;
max-width: 230px;
max-height: 230px;
}
img:nth-child(2):nth-last-child(3){
margin-right: 110px;
}