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限制图片的高/宽最大值。

天气真好!

bg.jpg

cat2.jpg

pic1.jpg

pic2.jpg

pic3.jpg

pic4.jpg

pic5.jpg

pic6.jpg

pic9.jpg

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;

}

gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值