您当前的位置:首页 > 电脑百科 > 程序开发 > 语言 > CSS

web前端入门到实战:纯CSS瀑布流与JS瀑布流

时间:2019-10-10 10:08:59  来源:  作者:

瀑布流

又称瀑布流式布局,是比较流行的一种网站页面布局方式。即多行等宽元素排列,后面的元素依次添加到其后,等宽不等高,根据图片原比例缩放直至宽度达到我们的要求,依次按照规则放入指定位置。

 

web前端入门到实战:纯CSS瀑布流与JS瀑布流

 

 

为什么使用瀑布流

瀑布流布局在我们现在的前端页面中经常会用的到,它可以有效的降低页面的复杂度,节省很多的空间,对于整个页面不需要太多的操作,只需要下拉就可以浏览用户需要看到的数据;并且,在当前这个App至上的时代,瀑布流可以提供很好的用户体验,通过结合下拉刷新,上拉加载进行数据的懒加载等操作,对于用户的体验感来说是接近于满分的!

瀑布流的特点

其实瀑布流的特点就是参差不齐的排列方式,以及流式布局的扩展性,可以通过界面展示给用户多条数据,并且让用户可以有向下浏览的冲动。

瀑布流的代码实现

1.纯 css 瀑布流:( multi-columns 方法 )

// 这里是第一次接触到 column-columns 这个属性,这是一个可以设置将div元素中的文本分成几列

//默认值是:auto

//写法:

column-count:3;

-moz-column-count:3; /* Firefox /

-webkit-column-count:3; / Safari and Chrome */

/* 注意:IE9及更早 IE 版本浏览器不支持 column-count 属性 */

//这里还会用到另一个属性 column-gap,用来调整边距,实现瀑布流布局

html结构代码如下:

<div class="demo-1"> 
 <div class="item"> 
 <div class="item_content content-lar" style="height:100px;" > 1</div> 
 </div> 
 <div class="item"> 
 <div class="item_content content-sma"style="height:150px;" > 2</div> 
 </div>
 <div class="item"> 
 <div class="item_content content-mid"style="height:50px;" > 3</div> 
 </div>
 <div class="item"> 
 <div class="item_content content-sma" style="height:200px;" > 4</div> 
 </div>
 <div class="item"> 
 <div class="item_content content-mid"style="height:60px;" > 5 </div> 
 </div>
 <div class="item"> 
 <div class="item_content content-lar"style="height:90px;" > 6</div> 
 </div> 
 <div class="item"> 
 <div class="item_content content-sma"> 7</div> 
 </div>
 <div class="item"> 
 <div class="item_content content-lar"style="height:120px;" > 8</div> 
 </div>
 <div class="item"> 
 <div class="item_content content-lar"> 9</div> 
 </div>
 <div class="item"> 
 <div class="item_content content-sma" style="height:100px;" > 10 </div> 
 </div>
 <div class="item"> 
 <div class="item_content content-mid"> 11 </div> 
 </div>
 <div class="item"> 
 <div class="item_content content-mid"style="height:100px;" > 12</div> 
 </div>
 <!-- more items --> 
</div>
web前端开发学习Q-q-u-n: 767中273后102 ,分享学习的方法和需要注意的小细节

CSS代码如下:

.demo-1{ 
 -moz-column-count:3; /* Firefox */
 -webkit-column-count:3; /* Safari 和 Chrome */
 column-count:3;
 -moz-column-gap: 1em;
 -webkit-column-gap: 1em;
 column-gap: 1em;
 width: 80%;
 margin:0 auto;
 }
 .item { 
 padding: 2em;
 margin-bottom: 2em;
 -webkit-column-break-inside: avoid;
 break-inside: avoid; /*防止断点*/
 background: #ccc;
 text-align: center;
 }

效果图:

 

web前端入门到实战:纯CSS瀑布流与JS瀑布流

 

 

这里有个弊端,这并不符合瀑布流的原理,如果使用纯css写瀑布流,则每一块都是从上往下排列,不能做到从左到右排列,并且不会识别哪一块图片放在哪个地方合适,若是再配合动态加载,效果会特别不好,所以只能通过JS来实现瀑布流。

那么这里用图片来分析一下我们想要的瀑布流是什么样的。

瀑布流的位置分析图解

如下方图片。假设一排放5张图片。当第一排排满足够多的等宽图片时,显示的是这样的。那么假如我们要放第6张图片的时候,应该放在什么位置呢?

web前端入门到实战:纯CSS瀑布流与JS瀑布流

 

 

 

如果按照我们的正常逻辑来想,应该是放在第一张图片下面,依次水平排列过去(如下图)

 

web前端入门到实战:纯CSS瀑布流与JS瀑布流

 

 

但现实并非如此!在瀑布流中,从第2行开始,接下去的每一张图片都会放在上行中高度最低的那一列图片下方。(如下图)

 

web前端入门到实战:纯CSS瀑布流与JS瀑布流

 

 

为什么呢?因为放置它之前,这一列的高度为所有列中最小,所以会放置在这个地方。

那么如果再继续放置下去,第七张图片应该放在第三列图片下方,以此类推。

 

web前端入门到实战:纯CSS瀑布流与JS瀑布流

 

 

所以每次加载图片时,会需要判断哪一列的图片累计的高度最小,那么下一张图片就放在哪一列,即瀑布流算法去判断图片的确定位置。

JS代码实现

实现思路:

  1. 设定每一列图片的宽度和间距
  2. 获取当前窗口的总宽度,从而根据图片宽度去旁段分成几列
  3. 获取所有图片元素,定义一个空数组来保存高度
  4. 遍历所有容器,开始判断 当页面加载完成,或页面宽度发生变化时,调用函数。
  • 如果当前处于第一行时: 直接设置图片位置【 即 top为间距的大小,left为(当前图片的宽度+间距) * 当前图片的值+间距大小 】,并保存当前元素高度。
  • 如果当前不处于第一行时:进行高度对比,通过遍历循环,拿到最小高度和相对应的索引,设置图片位置【 即 top为最小高度值+间距*2,left为 (当前图片的宽度+间距) * 索引 值+间距大小)】,并修改当前索引的高度为当前元素高度。
  1. 当页面加载完成,或页面宽度发生变化时,调用函数。

代码实现

<script type="text/JAVAscript">
 // 定义瀑布流算法函数
 function fall() {
 const minGap = 20; // 最小间距,让每一列的最小空隙可以自定义,避免太过拥挤的情况发生。但是,会通过计算得到真实的间距。
 const itemWidth = 300; // 每一项的宽度,即当前每一个图片容器的宽度。保证每一列都是等宽不等高的。
 const scrollBarWidth = getScrollbarWidth(); // 获取滚动条的宽度
 const pageWidth = window.innerWidth - scrollBarWidth; // 获取当前页面的宽度 = window.innerWidth - 滚动条的宽度
 const column = Math.floor(pageWidth / (itemWidth + minGap)); // 实际列数=页面宽度/(图片宽度+最小间距)
 const gap = (pageWidth - itemWidth * column) / column/2; // 计算真实间距 = (页面宽度- 图片宽度*实际列数)/实际列数/2
 const items = document.querySelectorAll('img'); // 获取所有的外层元素
 const heightArr = []; // 定义一个空数组,保存最低高度。
 // 获取滚动条的宽度
 function getScrollbarWidth() {
 const oDiv = document.createElement('div');//创建一个div
 // 给div设置样式。随便定义宽高,只要能获取到滚动条就可以
 oDiv.style.cssText = `width: 50px;height: 50px;overflowY: scroll;` 
 document.body.appendChild(oDiv);//把div添加到body中
 const scrollbarWidth = oDiv.offsetWidth - oDiv.clientWidth;// 使最大宽度和可视宽度相减,获得到滚动条宽度。
 oDiv.remove();//移除创建的div
 return scrollbarWidth;//返回滚动条宽度
 }
 for (let i = 0; i < items.length; i++) {
 // 遍历所有的外层容器
 const height = items[i].offsetHeight;
 // 如果当前处在第一行
 if (i < column) {
 // 直接设置元素距离上部的位置和距离左边的距离。
 items[i].style.cssText = `top: ${gap}px;left: ${(itemWidth + gap) * i + gap}px`;
 // 保存当前元素的高度。
 heightArr.push(height);
 } else {
 // 不是第一行的话,就进行比对。
 let minHeight = heightArr[0]; // 先保存第一项的高度
 let minIndex = 0; // 保存第一项的索引值
 for (let j = 0; j < heightArr.length; j++) {
 // 通过循环遍历比对,拿到最小值和最小值的索引。
 if (minHeight > heightArr[j]) {
 minHeight = heightArr[j];
 minIndex = j;
 }
 }
 // 通过最小值为当前元素设置top值,通过索引为当前元素设置left值。
 items[i].style.cssText = `top: ${minHeight + gap *2}px; left: ${(itemWidth + gap) * minIndex + gap}px`;
 // 并修改当前索引的高度为当前元素的高度
 heightArr[minIndex] = minHeight + gap + height;
 }
 }
 }
 // 页面加载完成调用一次。
 window.onload = fall;
 // 页面尺寸发生改变再次调用。
 window.onresize = fall;
</script>
web前端开发学习Q-q-u-n: 767中273后102 ,分享学习的方法和需要注意的小细节

最终效果图:


总结瀑布流布局原理

  • 设置图片宽度一致
  • 根据浏览器宽度以及每列宽度计算出列表个数,列表默认0
  • 当图片加载完成,所有图片依次放置在最小的列数下面
  • 父容器高度取列表数组的最大值

引申知识点

  • let,const以及var三者的区别
  • 滚动加载图片(懒加载原理)
  • 反撇号(`)基础知识
  • style和style.cssTest 的区别


Tags:CSS 瀑布流   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
作者:MudOnTire转发链接:https://segmentfault.com/a/1190000023103516前言瀑布流提供了一种错落有致的美观布局,被各种注重交互品味的素材网站(如:花瓣、unsplash)广泛应用。社...【详细内容】
2020-07-22  Tags: CSS 瀑布流  点击:(63)  评论:(0)  加入收藏
瀑布流又称瀑布流式布局,是比较流行的一种网站页面布局方式。即多行等宽元素排列,后面的元素依次添加到其后,等宽不等高,根据图片原比例缩放直至宽度达到我们的要求,依次按照规则...【详细内容】
2019-10-10  Tags: CSS 瀑布流  点击:(85)  评论:(0)  加入收藏
▌简易百科推荐
Chrome 正在试验 CSS @container 查询器功能,这是由 Oddbird 的 Miriam Suzanne 和一群网络平台开发者支持的 CSS 工作组 Containment Level 3 规范。@container 查询器使我...【详细内容】
2021-12-23  前端晚间课    Tags: CSS   点击:(8)  评论:(0)  加入收藏
CSS选择器很强大下面是我在工作中使用最多的一些选择器:相邻元素, 英文称为sibling, 也就是兄弟姐妹的意思.其实很形象, 比喻两个dom是相邻的.但是邻居很多, 紧密相邻的, 还...【详细内容】
2021-12-23  不只是个小前端    Tags:CSS选择器   点击:(7)  评论:(0)  加入收藏
这篇文章重点介绍一些强大的 CSS 代码片段,用它们可以执行一些繁重的布局编程工作,还能帮助我们构建强大的新式CSS布局。这里我们会介绍10 种新式 CSS 布局和大小调整技术,突出...【详细内容】
2021-12-21  前端晚间课    Tags:CSS   点击:(9)  评论:(0)  加入收藏
CSS框架提供了设计一致解决方案的基本结构,以解决前端web开发中的常见问题。它们提供了通用功能,可以针对特定场景和应用程序进行覆盖。这大大减少了开始创建应用程序和网站所...【详细内容】
2021-12-06  粤嵌教育    Tags:v   点击:(15)  评论:(0)  加入收藏
作者:前端进阶者来源:前端进阶学习交流一、前言 我们经常在网页上 ,游戏界面加载时会看到加载进度条的效果,我们往往会以为这些加载进度条的效果,很难实现。今天教大家JS+CSS结合...【详细内容】
2021-11-05  Nodejs开发    Tags:CSS   点击:(45)  评论:(0)  加入收藏
<template> <div> <div class="triangle"></div> </div></template><style scoped> .triangle { width: 0; height: 0; border-width: 20px; border-styl...【详细内容】
2021-11-04  荣邦小伙917    Tags:css   点击:(40)  评论:(0)  加入收藏
一提起图标,大家可能第一个会想到PS、美工等词语,但很多小图标现在根本都不需要再打开PS了。1、常见的括号( 前进或后退“>” ).arrow{ width:12rpx; height:12rpx; border-...【详细内容】
2021-10-12  滇東小贰锅    Tags:css   点击:(55)  评论:(0)  加入收藏
在过去的几年里,Web开发已经变得非常流行。每年都会发布许多前端框架,Bootstrap一直是最受欢迎的一个,但是,还有许多其他的框架,你可能没有听说过,但绝对值得一试。想学的同学可以...【详细内容】
2021-09-27  粤嵌教育    Tags:CSS框架   点击:(74)  评论:(0)  加入收藏
水平和垂直对齐第一种方式 : grid + place-items .parent { display: grid; place-items: center; } /*注: place-items 是 justify-items 和 align-items 的简写属性 */...【详细内容】
2021-09-02  又菜又爱学习的程序员    Tags:CSS   点击:(84)  评论:(0)  加入收藏
5个有用的 CSS 布局生成器1、 cssgr.id如果你是前端开发人员,这是一个非常有用的网站。你可以首先指定所需的行数和列数,或者在给定的选项中进行选择,然后为其生成代码。这使你...【详细内容】
2021-08-26  程序员文周    Tags:css布局   点击:(144)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条