菜单

JS图片预加载插件

2019年6月14日 - JavaScript

1)概念:

插件:

例子:

     
在支付H5项目中有时会碰着要加载大量图片的境况,利用预加载本事能够进步用户浏览时的心得。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>preload</title>
  <style>
    * {
      margin: 0;
      pading: 0;
    }

    a {
      text-decoration: none;
    }

    .box {
      text-align: center;
    }

    .btn {
      display: inline-block;
      height: 30px;
      line-height: 30px;
      border: 1px solid #ccc;
      background: #fff;
      padding: 0 10px;
      margin-right: 50px;
      color: #333;
    }

      .btn:hover {
        background: #eee;
      }
    /*进度条样式*/
    .loading {
      position: fixed;
      top: 0;
      left: 0;
      bottom: 0;
      right: 0;
      //撑满整个屏幕 background: #eee;
      text-align: center;
      font-size: 30px;
      font-weight: bold;
    }

    .progress {
      margin-top: 300px;
    }
  </style>
</head>
<body>
  <!--无序预加载需要写进度条,当加载完毕后才能操作;
    有序预加载可以不写进度条,加载完第一张后立即加载第二张、第三张、第四张...
  -->
  <div class="box">
    <img src="http://image.hnol.net/c/2010-11/14/21/201011142147143181-239867.jpg" id="img" alt="pic" width="1000">
    <p>
      <a href="javascript:;" rel="external nofollow" rel="external nofollow" class="btn" data-control="prev">上一张</a>
      <a href="javascript:;" rel="external nofollow" rel="external nofollow" class="btn" data-control="next">下一张</a>
    </p>
  </div>
  <!--进度条-->
  <div class="loading">
    <p class="progress">0%</p>
  </div>
  <script src="http://libs.baidu.com/jquery/1.11.1/jquery.min.js"></script>

  <script src="~/Scripts/preload.js"></script>
  <script>
    var imgs = ['http://image.hnol.net/c/2010-11/14/21/201011142147143181-239867.jpg',
      'http://www.picperweek.com/resource/image/dbc3c16b-5fc6-48e5-aa48-c64739739da2.png',
      'http://imgstore.cdn.sogou.com/app/a/100540002/406526.jpg'],
      index = 0,
      len = imgs.length;
    $progress = $('.progress');
    //有序预加载,可以不用写进度条部分,如果有写,需要手动配置each()、all()方法
    //      $.preload(imgs,{
    //        order:'ordered'
    //      });

    //调用无序预加载  --imgs 数组存放预加载的图片
    $.preload(imgs, {
      //每张图片加载(load事件)一次触发一次each()
      each: function (count) {
        //进度条显示百分比进度
        $progress.html(Math.round((count + 1) / len * 100) + '%');
      },
      //加载完毕
      all: function () {
        $('.loading').hide();
        document.title = '1/' + len;//初始化第一张
      }
    });
    //未封装成插件的无序预加载
    //    $.each(imgs,function(i,src){
    //      var imgObj = new Image();  //Image()实例用于缓存图片
    //
    //      $(imgObj).on('load error',function(){
    //        $progress.html(Math.round((count + 1) / len * 100) + '%');
    //
    //        if(count >= len - 1){
    //          $('.loading').hide();
    //          document.title = '1/' + len;
    //        }
    //        count++;//每加载完一张图片count加1
    //      });
    //
    //      imgObj.src = src;//缓存图片
    //    });
    //上一页,下一页按钮
    $('.btn').on('click', function () {
      if ('prev' === $(this).data('control')) {
        index = Math.max(0, --index);
      } else {
        index = Math.min(len - 1, ++index);
      }
      document.title = (index + 1) + '/' + len;
      $('img').attr('src', imgs[index]);
    });
  </script>
</body>
</html>

 1)概念:
懒加载也叫延迟加载:JS图片延迟加载,延迟加载图片或符合有些原则时才加载有个别图片。
预加载:提前加载图片,当用户须求查阅时可直接从本地缓存中渲染。

插件:

服务器端不同:懒加载的显要目标是用作服务器前端的优化,裁减请求数或推迟请求数。预加载能够说是捐躯服务器前端质量,换取越来越好的用户体验,那样能够使用户的操作获得最快的体现。

2)区别:

例子:

; (function ($) {

  function PreLoad(imgs, options) {
    //保存图片到数组
    this.imgs = (typeof imgs === 'string') ? [imgs] : imgs;
    this.opts = $.extend(PreLoad.defaults, options);

    // this._unordered();//如果只有无序预加载
    if (this.opts.order === 'ordered') {
      this._ordered();
    } else {
      this._unordered();//默认是无序预加载
    }
  };
  PreLoad.defaults = {
    order: 'unordered', //指定默认加载方式为无序
    each: null, //每一张图片加载完毕后执行
    all: null //所有图片加载完毕后执行
  };
  //有序预加载
  PreLoad.prototype._ordered = function () {
    var opts = this.opts,
      imgs = this.imgs,
      len = imgs.length,
      count = 0;

    load();
    function load() {
      var imgObj = new Image();

      $(imgObj).on('load error', function () {
        //相当于if(opts.each){ opts.each(); } ,如果有配置each()方法则调用,后面的all()同理
        opts.each && opts.each(count);

        if (count >= len) {
          //所有图片加载完毕
          opts.all && opts.all();
        } else {
          //如果没加载完,继续调用自身加载下一张
          load();
        }
        count++;
      });

      imgObj.src = imgs[count];//缓存图片
    };
  };

  //无序加载
  PreLoad.prototype._unordered = function () {
    var imgs = this.imgs,
      opts = this.opts,
      count = 0,
      len = imgs.length;

    $.each(imgs, function (i, src) {
      //判断图片数组中的每一项是否为字符串,不是字符串会导致出错,因此返回
      if (typeof src != 'string') return;

      var imgObj = new Image();

      $(imgObj).on('load error', function () {
        //判断opts.each是否存在,不存在则不执行
        opts.each && opts.each(count);

        if (count >= len - 1) {
          //判断opts.all是否存在,存在则执行
          opts.all && opts.all();
        }
        count++;
      });

      imgObj.src = src;//缓存图片
    });
  };

  //由于不用具体的对象去调用,因此用$.extend(object)挂载插件.
  $.extend({
    //preload为插件名
    preload: function (imgs, opts) {
      new PreLoad(imgs, opts);
    }
  });

})(jQuery);
; (function ($) {

    function PreLoad(imgs, options) {
        //保存图片到数组
        this.imgs = (typeof imgs === 'string') ? [imgs] : imgs;
        this.opts = $.extend(PreLoad.defaults, options);

        // this._unordered();//如果只有无序预加载
        if (this.opts.order === 'ordered') {
            this._ordered();
        } else {
            this._unordered();//默认是无序预加载
        }
    };
    PreLoad.defaults = {
        order: 'unordered', //指定默认加载方式为无序
        each: null, //每一张图片加载完毕后执行
        all: null //所有图片加载完毕后执行
    };
    //有序预加载
    PreLoad.prototype._ordered = function () {
        var opts = this.opts,
            imgs = this.imgs,
            len = imgs.length,
            count = 0;

        load();
        function load() {
            var imgObj = new Image();

            $(imgObj).on('load error', function () {
                //相当于if(opts.each){ opts.each(); } ,如果有配置each()方法则调用,后面的all()同理
                opts.each && opts.each(count);

                if (count >= len) {
                    //所有图片加载完毕
                    opts.all && opts.all();
                } else {
                    //如果没加载完,继续调用自身加载下一张
                    load();
                }
                count++;
            });

            imgObj.src = imgs[count];//缓存图片
        };
    };

    //无序加载
    PreLoad.prototype._unordered = function () {
        var imgs = this.imgs,
            opts = this.opts,
            count = 0,
            len = imgs.length;

        $.each(imgs, function (i, src) {
            //判断图片数组中的每一项是否为字符串,不是字符串会导致出错,因此返回
            if (typeof src != 'string') return;

            var imgObj = new Image();

            $(imgObj).on('load error', function () {
                //判断opts.each是否存在,不存在则不执行
                opts.each && opts.each(count);

                if (count >= len - 1) {
                    //判断opts.all是否存在,存在则执行
                    opts.all && opts.all();
                }
                count++;
            });

            imgObj.src = src;//缓存图片
        });
    };

    //由于不用具体的对象去调用,因此用$.extend(object)挂载插件.
    $.extend({
        //preload为插件名
        preload: function (imgs, opts) {
            new PreLoad(imgs, opts);
        }
    });

})(jQuery);

以上正是本文的全体内容,希望对我们的学习抱有援助,也期望大家多多辅助脚本之家。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>preload</title>
    <style>
        * {
            margin: 0;
            pading: 0;
        }

        a {
            text-decoration: none;
        }

        .box {
            text-align: center;
        }

        .btn {
            display: inline-block;
            height: 30px;
            line-height: 30px;
            border: 1px solid #ccc;
            background: #fff;
            padding: 0 10px;
            margin-right: 50px;
            color: #333;
        }

            .btn:hover {
                background: #eee;
            }
        /*进度条样式*/
        .loading {
            position: fixed;
            top: 0;
            left: 0;
            bottom: 0;
            right: 0;
            //撑满整个屏幕 background: #eee;
            text-align: center;
            font-size: 30px;
            font-weight: bold;
        }

        .progress {
            margin-top: 300px;
        }
    </style>
</head>
<body>
    <!--无序预加载需要写进度条,当加载完毕后才能操作;
        有序预加载可以不写进度条,加载完第一张后立即加载第二张、第三张、第四张...
    -->
    <div class="box">
        <img src="http://image.hnol.net/c/2010-11/14/21/201011142147143181-239867.jpg" id="img" alt="pic" width="1000">
        <p>
            <a href="javascript:;" class="btn" data-control="prev">上一张</a>
            <a href="javascript:;" class="btn" data-control="next">下一张</a>
        </p>
    </div>
    <!--进度条-->
    <div class="loading">
        <p class="progress">0%</p>
    </div>
    <script src="http://libs.baidu.com/jquery/1.11.1/jquery.min.js"></script>

    <script src="~/Scripts/preload.js"></script>
    <script>
        var imgs = ['http://image.hnol.net/c/2010-11/14/21/201011142147143181-239867.jpg',
            'http://www.picperweek.com/resource/image/dbc3c16b-5fc6-48e5-aa48-c64739739da2.png',
            'http://imgstore.cdn.sogou.com/app/a/100540002/406526.jpg'],
            index = 0,
            len = imgs.length;
        $progress = $('.progress');
        //有序预加载,可以不用写进度条部分,如果有写,需要手动配置each()、all()方法
        //            $.preload(imgs,{
        //                order:'ordered'
        //            });

        //调用无序预加载   --imgs 数组存放预加载的图片
        $.preload(imgs, {
            //每张图片加载(load事件)一次触发一次each()
            each: function (count) {
                //进度条显示百分比进度
                $progress.html(Math.round((count + 1) / len * 100) + '%');
            },
            //加载完毕
            all: function () {
                $('.loading').hide();
                document.title = '1/' + len;//初始化第一张
            }
        });
        //未封装成插件的无序预加载
        //        $.each(imgs,function(i,src){
        //            var imgObj = new Image();   //Image()实例用于缓存图片
        //
        //            $(imgObj).on('load error',function(){
        //                $progress.html(Math.round((count + 1) / len * 100) + '%');
        //
        //                if(count >= len - 1){
        //                    $('.loading').hide();
        //                    document.title = '1/' + len;
        //                }
        //                count++;//每加载完一张图片count加1
        //            });
        //
        //            imgObj.src = src;//缓存图片
        //        });
        //上一页,下一页按钮
        $('.btn').on('click', function () {
            if ('prev' === $(this).data('control')) {
                index = Math.max(0, --index);
            } else {
                index = Math.min(len - 1, ++index);
            }
            document.title = (index + 1) + '/' + len;
            $('img').attr('src', imgs[index]);
        });
    </script>
</body>
</html>

懒加载也叫延迟加载:JS图片延迟加载,延迟加载图片或符合某个条件时才加载有些图片。
预加载:提前加载图片,当用户须要查阅时可平昔从本地缓存中渲染。

 

二种工夫的真相:两个的作为是倒转的,七个是提前加载,一个是舒缓以至不加载。懒加载对服务器前端有肯定的化解压力效用,预加载则会追加服务器前端压力。

2)区别:
两种手艺的本质:两个的表现是倒转的,一个是提前加载,三个是舒缓乃至不加载。懒加载对服务器前端有早晚的缓慢解决压力作用,预加载则会扩大服务器前端压力。

你可能感兴趣的作品:

 

劳动器端不一样:懒加载的基本点指标是作为服务器前端的优化,减弱请求数或延缓请求数。预加载能够说是就义服务器前端品质,换取更加好的用户体验,这样能够使用户的操作得到最快的展现。

在开拓H5项目中不常会赶上要加载大批量图形的意况,利用预加载才干能够压实用户浏览时的体验。

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图