美文网首页
懒加载的原理

懒加载的原理

作者: LabRaDor2079 | 来源:发表于2017-08-25 11:38 被阅读0次

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

代码实现
既然懒加载的原理是基于判断元素是否出现在窗口可视范围内,首先我们写一个函数判断元素是否出现在可视范围内:

function isVisible($node){ var winH = $(window).height(), scrollTop = $(window).scrollTop(), offSetTop = $(window).offSet().top; if (offSetTop < winH + scrollTop) { return true; } else { return false; }}

再添加上浏览器的事件监听函数,让浏览器每次滚动就检查元素是否出现在窗口可视范围内:

$(window).on("scroll", function{ if (isVisible($node)){ console.log(true); }})

我们已经很接近了,现在我们要做的是,让元素只在第一次被检查到时打印true,之后就不再打印了

var hasShowed = false;$(window).on("sroll",function{ if (hasShowed) { return; } else { if (isVisible($node)) { hasShowed = !hasShowed; console.log(true); } }})

咦,我们好像已经实现了懒加载。 下面是我的实现:
展示代码

无限滚动
利用懒加载和AJAX,我们还可以实现无限滚动查看时间线的效果,下面是我的实现: - 展示代码
回到顶部
利用懒加载的原理,我们还可以实现在滚动页面一段距离后,出现回到顶部按钮的这种效果,下面是我的实现 - 展示代码

相关文章

  • 项目优化

    图片懒加载,数据懒加载, 路由懒加载 1.图片懒加载原理 1.1 开始时 不设置src属性 1.2 图片在可视区域...

  • webpack打包代码实现

    webpack模块加载 异步模块加载 通过 import()实现指定模块的懒加载操作 懒加载的核心原理就是创建js...

  • 图片懒加载和预加载

    图片懒加载的原理是什么? 首先明白为什么要懒加载: 懒加载即延迟,对于图片过多的页面,为了加快页面加载速度,我们需...

  • Vue路由异步组件

    vue异步组件和懒加载可以优化vue的性能 一、 原理 利用webpack对代码进行分割是懒加载的前提,懒加载就是...

  • 2017-02-19

    图片懒加载 效果预览 瀑布流布局 效果预览 木桶布局 效果预览 无限轮播 效果预览 原理 图片懒加载的原理当网页上...

  • OC底层原理14 - 类的加载之分类

    类的懒加载和非懒加载 在OC底层原理13 - 类的加载过程[https://www.jianshu.com/p/8...

  • 懒加载原理

    具体参考 https://www.jianshu.com/p/4876a4fe7731 前提:通过js给img元素...

  • 懒加载原理

    就是在浏览器的非可视区域内将原图片替换为一张小的图片,而且看不到其原图片,如果在可视范围内,则加载出原图片

  • 懒加载的原理

    文件路径: http://bbs.daxiangclass.com/?thread-22.htm 在本地设置一个假...

  • 懒加载的原理

    原理:先将img标签中的src链接设为同一张图片(空白图片),将其真正的图片地址存储再img标签的自定义属性中(比...

网友评论

      本文标题:懒加载的原理

      本文链接:https://www.haomeiwen.com/subject/ugrudxtx.html