zoukankan      html  css  js  c++  java
  • 前端优化:图片延迟加载(适合首屏以外的内容)

    原理:先用一张极小的图片来代替,等到内容加载完了,再向服务器请求真正的图片并替换,可以有效的减少等待时间。

    实现:

    <img src="" data-src="a.jpg">
    function loadImage(){
        var deferImages=document.getElementsByTagName('img');
        var curImg;
        var imgSrc;
        for(var i=0,len=deferImages.length;i<len;i++){
            curImg=deferImages[i];
            imgSrc=curImg.getAttribute('data-src');
            if(imgSrc){
                curImg.setAttribute('src',imgSrc);
            }
        }
    }
    
    window.onload=loadImage;

    这对于延迟加载首屏以后的内容很有用,提高加载速度。懒加载可以减少请求数(有可能不会去加载)或者延迟请求,减缓了服务器端的压力。

    可以有多种实现方式:

    1、使用settimeout或setinterval进行延迟加载,如果用户在加载前离开了,就不会去加载了。

    2、有条件的加载,当符合某个条件或者触发了某个事件才开始异步下载。

    3、可视区加载,仅加载用户可看到的区域,通过监控滚动条事件来加载图片。在距用户看到某图片一段距离前便开始加载,这样当用户往下拉的时候刚好可以看到图片。



  • 相关阅读:
    json_encode不编码中文字符的方式
    网站备份脚本
    英语动词大全
    多线程和多进程的区别【转载网络】
    解决curl中errno为51和60的错误
    ps修改图片文字
    如何设计充值消费的数据表
    LoRa与NB-IoT对比(转载)
    vuejs 使用vue-cli引入bootstrap
    关于防火墙的规则
  • 原文地址:https://www.cnblogs.com/yanyd/p/4558833.html
Copyright © 2011-2022 走看看