瀑布流

图片懒加载

图片都是一个loading的加载状态

举例:瞬间,互联网要获取20张网络图片的请求,稍等片刻之后,并不是一开始就展示所有的图片,滚动哪里就加载几张图片

图片懒加载的作用

作用: 缓解网络压力,使得用户体验更好

img缓存机制

图片懒加载如何展现的呢,img指向一个图片,其它的img也只是加载加载这个图片,其它的图片片加载的时候,直接从缓存里面进行加载

图片的懒加载的问题

  • 如何判断图片是否出现在我们的视野当中
  • 如何加载这个图片

如何加载这个图片

在img标签中把data-src里面的值放到src这个属性上面

如何判断一个元素是否出现在我们的视野中呢

1.窗口的高度
2.滚动的距离
3.元素相当于顶点之间的距离

滚动的高度的判断

$(window).height() = $(window).scrollTop + $(node).offset().top()
img1

$(node).offset()出现问题

可能是没有清除浮动

图片懒加载的优化

已经加载的图片可以添加isLoaded = true 这个属性,然后选择器判断的时候可以过滤一下有这个属性的元素

$().not('[data-isloaded]').each(function(){
    
})

瀑布流布局

  • 宽度相等,高度不相等

语言描述: 设置一个数组,每当放一个元素到数组中的一个元素的时候,该元素的高度更新,在下一次放入元素当中的时候,需要进行比较每一列的高度,选择高度最小的一个元素插入这个数组。

代码描述:

placeholder.com

生成的测试图片

.outerWidth([includeMargin])

includeMargin(默认值:false)
类型:布尔值
一个布尔值,指示是否在计算中包含元素的边距。

瀑布流答疑

瀑布流新闻站

如何实现一边下拉,一边展现

实现思路

  1. 假设功能已经实现了,然后把功能一个一个拼接起来
  2. 直接把一步一步地写

实现步骤

  1. 获取数据

  2. 把数据拼接成dom放到页面上

  3. 使用瀑布流去摆放dom 位置

  4. 获取10条数据

  5. 把10条数据拼接成dom放到页面上

  6. 使用瀑布流去摆放dom 位置

  7. page++

当页面滚动(或者某个条件下)

  1. 获取page =2 的10条数据
  2. 把10条数据拼接成dom放到页面上
  3. 使用瀑布流去摆放dom 位置
  4. page++

简述图片懒加载的实现原理

原理:先将img标签中的src链接设为同一张图片(空白图片),将其真正的图片地址存储在img标签的自定义属性中(比如data-src)。当js监听到该图片元素进入可视窗口时,即将自定义属性中的地址存储到src属性中,达到懒加载的效果。
这样做能防止页面一次性向服务器响应大量请求导致服务器响应慢,页面卡顿或崩溃等问题。

简述瀑布流布局的实现原理

瀑布流布局由pinterest.com网站首创,它的原理是:先通过计算出一排能够容纳几列元素,然后寻找各列之中所有元素高度之和的最小者,并将新的元素添加到该列上,然后继续寻找所有列的各元素之和的最小者,继续添加至该列上,如此循环下去,直至所有元素均能够按要求排列为止

木桶效应

木桶效应
假设我们手里有20张照片,这些照片可以在保持宽高比的情况下进行放大或者缩小。选定一个基准高度比如200px

  • 拿第1张照片,锁定宽高比高度压缩到200px,放到第一行
  • 拿第2张照片,高度压缩到200px,放到第一行,图片1的后面
  • ...
  • 拿第5张照片,高度压缩到200px,放到第一行。oh,不好,空间不够,放不下了
  • 把前面水平依次排放好的4个图片当成一个整体,等比拉伸,整体宽度正好撑满容器
  • 第5张照片从下一行开始,继续...
    以上,就是木桶布局的原理。

如何判断元素出现在用户视野?

窗口的高度 + 滚动的距离 ?= 元素相当于顶点之间的距离

$(window).height() = $(window).scrollTop + $(node).offset().top()

如何判断一个浏览器滚动到底部

 $(function() {  
                var winH = $(window).height(); //页面可视区域高度  
                $(window).scroll(function() {  
                    var pageH = $(document.body).height(); //整个网站页面总高度 
                    var scrollH = $(window).scrollTop(); //滚动条高度  
                    var differ = (pageH - winH - scrollH) //差值;  
                        if (differ < 0.02) { //代表滚到条已经到底 
                                 alert("我是有底线的") ;
                        }
                });  
            });  

实现课程中图片懒加载的效果

任务1

实现课程中瀑布流布局效果

任务二

img中alt的属性

如果无法显示图像,浏览器将显示替代文本,就像这样:

实现课程中的瀑布流布局

this

当在其他函数上调用init()的函数或者参数的时候的时候,记得加上_this,否则将无法实现调用函数

let

ES6 新增了let命令,用来声明局部变量。它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效,而且有暂时性死区的约束。

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

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,760评论 1 92
  • 简述图片懒加载的实现原理 原理:先将img标签中的src链接设为同一张图片(空白图片),将其真正的图片地址存储再i...
    饥人谷_阿银阅读 389评论 0 0
  • html结构 (Emmet) (div.box>div.pic>img[src="images/$.jpg"])*...
    LaBaby_阅读 640评论 0 0
  • 人生就像一列开往坟墓的列车,路途上会有很多站,很难有人至始至终陪你走完全程,当陪你的人要下车时,即便不舍,也要心存...
    sunny519111阅读 972评论 0 0
  • 瀑布流典型网站 花瓣网、堆糖 [目录] 瀑布流布局原理大体思路具体思路 插件封装(5步) 动态渲染需求分析渲染第一...
    顽皮的雪狐七七阅读 3,961评论 0 6