zoukankan      html  css  js  c++  java
  • JS 图片懒加载

    所谓懒加载就是在图片进入 *可视区域* 前,用 *同一张* 图片作为图片的 src 属性值,这样可减少请求及带宽。懒加载的重点是:判断元素是否进入可视区域?

    元素距离文档顶部高度(这个值固定不变) - 整个文档被滚动高度(浏览器滚动条向下滚动高度) <= 可视高度,表示元素进入可视区域  

    品牌vi设计公司http://www.maiqicn.com 办公资源网站大全https://www.wode007.com

    Demo: 

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8">
    <title>懒加载</title>
    <style type="text/css">
    * { padding: 0; margin:0; }
    img { display: block; height: 171px;}
    </style>
    </head>
    <body>
    <img src="../site/images/users_avatar/user1.png" data-loaded="1">
    <img src="../site/images/users_avatar/user2.png" data-loaded="1">
    <img src="../site/images/users_avatar/user3.png" data-loaded="1">
    <img src="../site/images/users_avatar/user4.png" data-loaded="1">
    <img src="../site/images/users_avatar/user5.png" data-loaded="1">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    </body>
    <script type="text/JavaScript">
    window.onload = function () {
    window.onscroll = function () {
    // 重点:判断元素是否进入可视区域?
    // 元素距离文档顶部高度(这个值固定不变)减去
    // 整个文档被滚动高度(浏览器滚动条向下滚动高度)
    // 小于等于可视高度,表示元素进入可视区域
    var images = document.querySelectorAll('img');
    var scroll_h = document.documentElement.scrollTop;
    var visual_h = window.innerHeight;
    // 实现等待加载效果
    setTimeout(function() {
    for (var i = 5; i < images.length; i++) {
    if (images[i].getAttribute('data-loaded') === '0'
    && images[i].offsetTop - scroll_h <= visual_h
    ) {
    images[i].src = "../site/images/users_avatar/user" + (i + 1) + ".png";
    images[i].setAttribute('data-loaded', '1');
    }
    }
    }, 550);
    }
    }
    </script>
    </html>
  • 相关阅读:
    Jquery Validate验证是否为图片格式
    cosbench read异常解决办法。 Unable to verify integrity of data download. Client calculated content hash didn't match hash calculated by Amazon S3. The data may be corrupt.
    Ceph RGW 和 niginx 配置要点
    RGW/SWIFT对象存储性能测试工具--COSBench安装
    CEPH DAYS 2016 APAC ROADSHOW Ceph社区分享资料
    使用s3cmd操作ceph rgw
    gdb调试常用实用命令和core dump文件的生成
    What is GSLB
    转 ext文件系统及块组
    转 浅谈算法和数据结构: 十 平衡查找树之B树
  • 原文地址:https://www.cnblogs.com/xiaonian8/p/13696108.html
Copyright © 2011-2022 走看看