100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > html 实现格子效果图 css 实现的九宫格图片展示

html 实现格子效果图 css 实现的九宫格图片展示

时间:2019-07-22 14:14:04

相关推荐

html 实现格子效果图 css 实现的九宫格图片展示

朋友圈、微博的图片展示会根据数量不同而样式不同,这也可以用纯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;

}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。