纯CSS3怎么创建瀑布流布局?columns方法浅析

广告:宝塔Linux面板高效运维的服务器管理软件 点击【 https://www.bt.cn/p/uNLv1L 】立即购买

纯CSS3怎么创建瀑布流布局?columns方法浅析

在之前的文章《CSS3怎么给背景图片添加动态变色效果》中,我们介绍了创建变色背景图像动画的方法,让网页显得高级感十足!这次我们来聊聊使用CSS3 column系列属性怎么实现瀑布流布局,感兴趣的朋友可以去了解一下~

我们提到CSS响应布局的,就会想要使用Grid和Flexbox来实现,其实它们也有一些局限性。像瀑布流布局这种,就无法用它们来简单实现。

这其中的原因就是瀑布流一般来说都是宽度一致,但是高度是根据图片自适应的。并且图片的位置也是根据在上方图片的位置而定的。

那么如何使用纯CSS3实现瀑布流布局呢?我们可以利用CSS3 column系列属性!

下面我们就先直接上代码:

<!DOCTYPE html><html><head><meta charset="utf-8"><style>body,html {position: relative;width: 100%;height: 100%;background: #4f000b;font-family: "PT Mono", monospace;}.masonry {-moz-column-count: 1; column-count: 1;   /* 设置列数 */-moz-column-gap: 0;column-gap: 0;  /* 设置列间距 */counter-reset: item-counter;}/* 根据不同的屏幕宽度 设置不同的列数*/@media screen and (min-width: 400px) {.masonry {-moz-column-count: 2;  column-count: 2;}}@media screen and (min-width: 600px) {.masonry {-moz-column-count: 3;column-count: 3;}}@media screen and (min-width: 800px) {.masonry {-moz-column-count: 4;column-count: 4;}}@media screen and (min-width: 1100px) {.masonry {-moz-column-count: 5;column-count: 5;}}.item {box-sizing: border-box;-moz-column-break-inside: avoid;break-inside: avoid;padding: 10px;counter-increment: item-counter;}.item__content {position: relative;display: flex;flex-direction: column;justify-content: center;align-items: center;height: 220px;font-size: 40px;color: #360007;background: currentColor;box-sizing: border-box;color: #720026;}.item__content:hover {background: #9b0034;}.item__content:before {position: absolute;top: 0;left: 0;font-size: 13px;width: 2em;height: 2em;line-height: 2em;text-align: center;font-weight: bold;background-color: #222;content: counter(item-counter);}.item__content--small {color: #ce4257;height: 100px;}.item__content--small:hover {background: #d66274;}.item__content--medium {color: #ffc093;height: 175px;}.item__content--medium:hover {background: #ffd8bc;}.item__content--large {color: #ff7f51;height: 280px;}.item__content--large:hover {background: #ff9d7a;}</style></head><body><div class="masonry"><div class="item"><div class="item__content"></div></div><div class="item"><div class="item__content item__content--small"></div></div><div class="item"><div class="item__content item__content--medium"></div></div><div class="item"><div class="item__content item__content--small"></div></div><div class="item"><div class="item__content item__content--medium"></div></div><div class="item"><div class="item__content"></div></div><div class="item"><div class="item__content item__content--large"></div></div><div class="item"><div class="item__content item__content--medium"></div></div><div class="item"><div class="item__content item__content--small"></div></div><div class="item"><div class="item__content"></div></div><div class="item"><div class="item__content item__content--large"></div></div><div class="item"><div class="item__content"></div></div><div class="item"><div class="item__content item__content--small"></div></div><div class="item"><div class="item__content item__content--large"></div></div><div class="item"><div class="item__content item__content--medium"></div></div><div class="item"><div class="item__content item__content--small"></div></div><div class="item"><div class="item__content item__content--medium"></div></div><div class="item"><div class="item__content"></div></div><div class="item"><div class="item__content item__content--small"></div></div></div></body></html>
登录后复制

效果如下图所示:

ok,瀑布流布局实现了!那么下面分析一下上述代码,给大家介绍几个关键的css属性:

@media 查询:可以针对不同的屏幕尺寸设置不同的样式

@media mediatype and|not|only (media feature) {    CSS-Code;}
登录后复制

column-count属性:指定某个元素应分为的列数。

column-gap 属性:指定列间距。

column-gap: length|normal;length    一个指定的长度,将设置列之间的差距    normal    指定一个列之间的普通差距。 W3C建议1EM值
登录后复制

break-inside属性:描述了在多列布局页面下的内容盒子如何中断,如果多列布局没有内容盒子,这个属性会被忽略。

上例中:

.item { break-inside: avoid; box-sizing: border-box; padding: 10px; }
登录后复制

break-inside:avoid为了控制文本块分解成单独的列,以免项目列表的内容跨列,破坏整体的布局。

counter-increment属性:递增一个或多个计数器值,通常用于counter-reset属性和content属性。例如上例中:

.item {counter-increment: item-counter;}.item__content:before {content: counter(item-counter);}
登录后复制

PHP中文网平台有非常多的视频教学资源,欢迎大家学习《css视频教程》!

以上就是纯CSS3怎么创建瀑布流布局?columns方法浅析的详细内容,更多请关注9543建站博客其它相关文章!

广告:SSL证书一年128.66元起,点击购买~~~

9543建站博客
一个专注于网站开发、微信开发的技术类纯净博客。
作者头像
admin创始人

肥猫,知名SEO博客站长,14年SEO经验。

上一篇:bootstrap模态框有什么用
下一篇:段落每行渐变色文本效果

发表评论

关闭广告
关闭广告