html 瀑布流样式,前端小技巧:纯CSS实现瀑布流(Masonry)

logo-480.png

masonry-poster.png

瀑布流提供了一种错落有致的美观布局,被各种注重交互品味的素材网站(如:花瓣、unsplash)广泛应用。社区也提供了不少瀑布流布局的工具,如:masonry 、colcade 等。常规的实现瀑布流的做法是用 JS 动态的计算“砖块”的尺寸和位置,计算量大、性能差。今天给大家介绍一种使用纯 CSS 实现瀑布流的方法,简洁优雅。主要使用到了 CSS 中的多列属性 columns。

在使用一个比较陌生的 CSS 属性之前,习惯性的了解一下它的兼容性,去 caniuse.com 瞅一眼:

columns.jpg

看着兼容性还不错,那就放心的用吧。

HTML

先构造页面结构:

353e78ca458bef9c425d6226a9d13678.png

Title Goes Here

Lorem, ipsum dolor sit amet consectetur adipisicing elit. Quis quod et

deleniti nobis quasi ad, adipisci perferendis totam, ducimus incidunt

dolore aut, quae quaerat architecto quisquam repudiandae amet nostrum

quidem?

...more...

在 div.masonry 容器中可以塞进任意多的 “砖块” div.item,“砖块” 中的图片可以从 unsplash 中随机获取,且可以指定图片的尺寸。

CSS

容器:.masonry {

width: 1440px; // 默认宽度

margin: 20px auto; // 剧中

columns: 4; // 默认列数

column-gap: 30px; // 列间距

}

砖块:.item {

width: 100%;

break-inside: avoid;

margin-bottom: 30px;

}

.item img {

width: 100%;

}

.item h2 {

padding: 8px 0;

}

.item P {

color: #555;

}

上面的样式其他都挺好理解,唯独 break-inside 这个属性比较陌生。让我们看一下去掉 break-inside 之后会有什么问题吧:

no-break-inside.jpg

可以看到有两个“砖块”的文字跑到上面和图片分开了。所以当设置了 break-inside: avoid 之后可以避免“砖块”内部的内容被断开。

不同屏幕尺寸适配

以上样式默认适配 PC,在其他尺寸设备上需要重新设置列数、列间距等样式,可以通过 media query 进行适配,比如:

ipad pro:@media screen and (min-width: 1024px) and (max-width: 1439.98px) {

.masonry {

width: 96vw;

columns: 3;

column-gap: 20px;

}

}

ipad:@media screen and (min-width: 768px) and (max-width: 1023.98px) {

.masonry {

width: 96vw;

columns: 2;

column-gap: 20px;

}

}

mobile:@media screen and (max-width: 767.98px) {

.masonry {

width: 96vw;

columns: 1;

}

}注意:屏幕尺寸区间不要有交集,也不要有缺口!

好了,大功告成,来张全家福!

masonry-sizes.jpg每天一个小技巧(Tricks by Day),量变引起质变,希望你和我一起每天多学一点,让技术有趣一点。

所有示例将会汇总到我的 tricks-by-day github项目中,欢迎大家莅临指导 😊

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值