瀑布流-----响应式图片加载技术

       瀑布流这项技术在现在很流行,各大网站,特别是关于的图片的网站都在利用这项技术来进行图片的布局,来吸引客户的眼球。像蘑菇街,图库,美丽说,等等。首先是,我们要理解瀑布流的技术原理。

 问:什么是瀑布流技术?

答:瀑布流技术是关于图片的加载的技术,响应式的加载。什么是响应式的加载呢?就是根据不同的视图窗口的尺寸,而来匹配不同的css样式,进行不同的样式匹配。专业的来讲,就是我前端开发师在页面的设计,是要根据用户的行为,不同的设备(屏幕的尺寸,分辨率,屏幕的定向)来进行不同的布局,需要不断的调整和响应。我们学过不同的布局框架,像栅格系统就是基于响应式布局的。在网页的图片加载的过程中,我们不是在页面的加载的时候,就把图片加载完了,这样,会耗费用户的流量,降低客户的体验度的。

问:既然如此,我们应该怎么办呢,怎样提高用户的体验度?

答 : 我们可以利用响应式的理念。就是用户在浏览图片的时候,我们可以设计响应式的浏览体验,也就是说,我们可以根据用户的观看视图窗口来进行加载需要的浏览的图片。就是根据用户的下拉滚动条,也就是说,我们可以监听onscroll事件来进行判断用户的是否有需求来进行观看图片。这个事件是响应式加载的关键。也就是说,我们图片的容器加上卷起来的距离的大于视图窗口的距离时,我们就触发onscroll事件。也就是说,就发起请求加载图片的事件。是ajax或者是跨域的请求。这样,就做到响应式的图片的加载功能的。根据不同的浏览距离就可以加载不同的图片。当然,我们还有把加载下来的数据push到原来的数据库中,这样,就加载不同的数据了。

问 : 瀑布流的尺寸,排列的方式是怎么样实现的?

答 :有两种方案。我们先看第一种方案,就是按照位置的计算方法来进行的。思路是这样的:把瀑布流的看做 列 容器 格子 ,如图所示:



首先,我们要计算我们的容器要容下几列瀑布流,这个要根据我们的容器的宽度,来进行计算:计算方法,如图所示:


1 : 容纳的列数: 是要根据我们的屏幕的(也就是可视窗口的宽度/(格子的宽度+间距));然后,向下取整,这样,计算的结果就是我们要的是容纳的列数。这样,在不同的设备下,我们要计算出的容纳的列数。

2 :容器的居中问题:为了保证我们的容器居中,我们还要计算的是容器的宽度:就是我们要将容器的宽度设置为:列数*(格子宽度+间距)-间距; 这样,我们可以保证我们的容器居中了。一行有几列,然后,乘以(格子的宽度 + 间距) 这个是总间距,然后减去间距,就可以让容器的居中。这样,就提高用户的美观。需要注意的是,当容器的宽度计算出来的时候,我们在代码执行顺序的时候,要在显示。如果,要显示,再计算的话是,会产生的页面的抖动。造成页面的体验不好。

3 : 排序的开始: 先把列数的每个格子放进每个列中,然后,去寻找的每个列数的高度最小的列数,然后,把格子放进去,这样,我们就能及时把空白的地方补上。left 的值是:列序号*(格子的宽度+间距)top :  列高 + 间距;并刷新的高度。怎么样找到高度最短的列数?就是可以通过for循环来进行遍历所有的列数,来判断最小的高度。遍历所有的格子,然后,直达重新排序。

4:把事件操作都挂载window.onload 和 window.onresize上,这样,我们的瀑布流的页面效果就出来了。

问 : 这样的思路有没有什么弊端?

答 :这样的设计看起来很美好,但是,结合异步的数据加载时,还有几个弊端的。弊端的问题如下:


问 : 有没有解决的方案呢?

答 :   有的,因为主要是消耗计算机的性能,每当缩放窗口的时,都会触发事件。在缩放的时候,还有进行重新排序。这样,就大量的消耗性能,页面滚动到底部的时候,需要发起请求数据,但是,只会照成新增的节点排序。解决方案是可以通过定时器来进行感知窗口的尺寸变化,如果一直在变化的话,就不必的触发请求的事件,这样,就不必的耗损计算机的性能。代码如下:



     也就是说,通过定时器的监听的话,我们可以降低计算机的运行耗能。 也就是说,当resize的值大于100的时候,清除定时器的效果。然后,是在窗口的变化的时候,我们可以启动的我们的定时器的。

2 : 如果每一次的数据的加载的时候,我们都会重新排序,这样,就比较耗损性能,我们的结局方案是,用一个数组来保存整个全局数据,然后,就可以直接调用排序的计算方法,在数据的加载时候,这样的话,就不必的重新要排序了。

-------------------------------------------------------------------------------------------->

用面向对象的思想写瀑布流。代码如下:


这个源码是非常不错的。我们可以了解一下。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,726评论 1 92
  • 所谓瀑布流,就是图片分几列有规律的排列,但是这里的排列是有要求的,普通的浮动布局会使图片与图片之间有很多的空隙,这...
    小飞侠zzr阅读 814评论 0 0
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    wzhiq896阅读 1,730评论 0 2
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    love2013阅读 2,303评论 0 11
  • github地址little-waterfall-framework-** 这里把整一个瀑布流小框架的实现思路写出...
    Tuberose阅读 6,413评论 12 123