ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

JS实现图片懒加载

2019-07-08 22:01:11  阅读:245  来源: 互联网

标签:src https img JS lazyload 加载 图片


JS实现图片懒加载

懒加载技术

懒加载(LazyLoad)是前端优化的一种有效方式,极大的提升用户体验,图片一直是页面加载的流浪大户,现在一张图片几兆已经是很正常的事,远远大于代码的大小。

原理:页面加载后只让文档可视区内的图片显示,其它不显示,随着用户对页面的滚动,判断其区域位置,生成img标签,让到可视区的图片加载出来。

所用相关技术:给img加属性 (例如data-src),将图片的地址赋值给他,这样就生成img标签后再把data-src的值赋给img的src(通过dataset.src或者getAttribute('src'),再赋值给img.setAttribute('src'))。

 

jqueryLazyload方式

下载链接:https://pan.baidu.com/s/1gyIzuHPfE7xvztwd8v8qGg 密码:48kw

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style type="text/css">
            *{
                margin:0px;
                padding: 0;
            }
            .wrap{
                overflow: hidden;
                width:915px;
                background:#2d2d2d;
                margin:50px auto;
                border-radius:10px;
                /*font-size:0px;*/
            }
            .wrap img{
                float:left;    
                display: block;
                width:280px;
                height:180px;
                margin:10px 10px;
                border:2px solid #7c7c7c;
                border-radius:10px;
            }
        </style> 
    </head>
    <body>
        
        <div class="wrap"> 
            <img src="js/images2/1.jpg" />
            <img src="js/images2/2.jpg" />
            <img src="js/images2/3.jpg" />
            <img src="js/images2/4.jpg" />
            <img src="js/images2/5.jpg" />
            <img src="js/images2/6.jpg" />
            <img src="js/images2/7.jpg" />
            <img src="js/images2/1.jpg" />
            <img src="js/images2/2.jpg" />
            <img src="js/images2/3.jpg" />
            <img src="js/images2/4.jpg" />
            <img src="js/images2/5.jpg" />
            <img src="js/images2/6.jpg" />
            <img src="js/images2/7.jpg" />
            <img src="js/images2/1.jpg" />
            <img src="js/images2/2.jpg" />
            <img src="js/images2/3.jpg" />
            <img src="js/images2/4.jpg" />
            <img src="js/images2/5.jpg" />
            <img src="js/images2/6.jpg" />
            <img src="js/images2/7.jpg" />
            <img src="js/images2/1.jpg" />
            <img src="js/images2/2.jpg" />
            <img src="js/images2/3.jpg" />
            <img src="js/images2/4.jpg" />
            <img src="js/images2/5.jpg" />
            <img src="js/images2/6.jpg" />
            <img src="js/images2/7.jpg" />
            <img src="js/images2/1.jpg" />
            <img src="js/images2/2.jpg" />
            <script src="js/jquery-1.11.1.min.js"></script>
            <script src="js/lazyload.js"></script>
            <script>
              $("img").lazyload({
               placeholder :"images2/loading.gif", //用图片提前占位
                // placeholder,值为某一图片路径.此图片用来占据将要加载的图片的位置,待图片加载时,占位图则会隐藏
              effect: "fadeIn", // 载入使用何种效果
                // effect(特效),值有show(直接显示),fadeIn(淡入),slideDown(下拉)等,常用fadeIn
              threshold: 200, // 提前开始加载
                // threshold,值为数字,代表页面高度.如设置为200,表示滚动条在离目标位置还有200的高度时就开始加载图片,可以做到不让用户察觉
             // event: 'click',  // 事件触发时才加载
                // event,值有click(点击),mouseover(鼠标划过),sporty(运动的),foobar(…).可以实现鼠标莫过或点击图片才开始加载,后两个值未测试…
              //container: $("#container"),  // 对某容器中的图片实现效果
                // container,值为某容器.lazyload默认在拉动浏览器滚动条时生效,这个参数可以让你在拉动某DIV的滚动条时依次加载其中的图片
              //failurelimit : 10 // 图片排序混乱时
                 // failurelimit,值为数字.lazyload默认在找到第一张不在可见区域里的图片时则不再继续加载,但当HTML容器混乱的时候可能出现可见区域内图片并没加载出来的情况,failurelimit意在加载N张可见区域外的图片,以避免出现这个问题.
             });
            </script>
        </div>
    </body>
</html>

 

echo.js方式

echo.js是一款非常简单实用轻量级的图片延时加载插件,如果你的项目中没有依赖jquery,那么这将是个不错的选择,50行代码,压缩后才1k。当然你完全可以集成到自己项目中去。

下载地址:https://github.com/helijun/helijun/tree/master/plugin/echo

<style>
  .demo img { 
    width: 736px; 
    height: 490px; 
    background: url(images/loading.gif) 50% no-repeat;}
</style>
<div class="demo">
    <img class="lazy" src="images/blank.gif" data-echo="images/big-1.jpg">
</div>
<script src="js/echo.min.js"></script>

<script>

Echo.init({
    offset: 0,//离可视区域多少像素的图片可以被加载
   throttle: 0 //图片延时多少毫秒加载
}); 

</script>

说明:blank.gif是一张背景图片,包含在插件里了。图片的宽高必须设定,当然,可以使用外部样式对多张图片统一控制大小。data-echo指向的是真正的图片地址。

 

更多阅读:

JavaScript如何实现图片懒加载(lazyload) 提高用户体验(增强版):https://www.jb51.net/article/98692.htm

前端实现图片懒加载(lazyload)的两种方式

https://www.cnblogs.com/liliangel/p/6122836.html

js实现图片懒加载:https://www.jianshu.com/p/4f6ea540516a

      

标签:src,https,img,JS,lazyload,加载,图片
来源: https://www.cnblogs.com/-wenli/p/11154076.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有