全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JS图片预加载插件详解

在开发H5项目中有时候会遇到要加载大量图片的情况,利用预加载技术可以提高用户浏览时的体验。

1)概念:

懒加载也叫延迟加载:JS图片延迟加载,延迟加载图片或符合某些条件时才加载某些图片。
预加载:提前加载图片,当用户需要查看时可直接从本地缓存中渲染。

2)区别:

两种技术的本质:两者的行为是相反的,一个是提前加载,一个是迟缓甚至不加载。懒加载对服务器前端有一定的缓解压力作用,预加载则会增加服务器前端压力。

服务器端区别:懒加载的主要目的是作为服务器前端的优化,减少请求数或延迟请求数。预加载可以说是牺牲服务器前端性能,换取更好的用户体验,这样可以使用户的操作得到最快的反映。

例子:

<!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>

插件:

; (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);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# JS图片预加载插件  # JS图片预加载  # JS图片加载  # JS+CSS实现图片预加载与背景图上中下切图  # javascript实现图片预加载和懒加载  # js中延迟加载和预加载的具体使用  # JS图片预加载三种实现方法解析  # JS实现预加载视频音频/视频获取截图(返回canvas截图)  # JavaScript前端静态资源预加载实现示例  # 加载  # 进度条  # 第一张  # 完毕后  # 下一张  # 是否存在  # 下一页  # 上一页  # 两种  # 中有  # 有一定  # 不存在  # 可以使用  # 可直接  # 时才  # 则会  # 也叫  # 大家多多  # 不写  # 四张 


相关文章: 实现虚拟支付需哪些建站技术支撑?  如何通过虚拟主机快速搭建个人网站?  青岛网站建设如何选择本地服务器?  制作充值网站的软件,做人力招聘为什么要自己交端口钱?  如何快速登录WAP自助建站平台?  建站之星伪静态规则如何正确配置?  建站之星如何快速更换网站模板?  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?  如何在万网自助建站中设置域名及备案?  如何快速使用云服务器搭建个人网站?  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  如何在IIS服务器上快速部署高效网站?  头像制作网站在线制作软件,dw网页背景图像怎么设置?  Bpmn 2.0的XML文件怎么画流程图  建站之星logo尺寸如何设置最合适?  建站之星伪静态规则如何设置?  大型企业网站制作流程,做网站需要注册公司吗?  建站之星后台管理:高效配置与模板优化提升用户体验  如何访问已购建站主机并解决登录问题?  子杰智能建站系统|零代码开发与AI生成SEO优化指南  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  建站主机如何选?高性价比方案全解析  C++时间戳转换成日期时间的步骤和示例代码  公司网站制作费用多少,为公司建立一个网站需要哪些费用?  如何构建满足综合性能需求的优质建站方案?  网站制作的步骤包括,正确网址格式怎么写?  香港网站服务器数量如何影响SEO优化效果?  常州自助建站工具推荐:低成本搭建与模板选择技巧  哈尔滨网站建设策划,哈尔滨电工证查询网站?  Thinkphp 中 distinct 的用法解析  枣阳网站制作,阳新火车站打的到仙岛湖多少钱?  如何制作网站标识牌,动态网站如何制作(教程)?  建站之星代理费用多少?最新价格详情介绍  建站之星展会模板:智能建站与自助搭建高效解决方案  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  建站之星导航菜单设置与功能模块配置全攻略  如何解决ASP生成WAP建站中文乱码问题?  如何确保FTP站点访问权限与数据传输安全?  安徽网站建设与外贸建站服务专业定制方案  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  建站之星24小时客服电话如何获取?  网站建设制作、微信公众号,公明人民医院怎么在网上预约?  网站按钮制作软件,如何实现网页中按钮的自动点击?  建站主机服务器选型指南与性能优化方案解析  建站之星ASP如何实现CMS高效搭建与安全管理?  如何生成腾讯云建站专用兑换码?  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  网站制作价目表怎么做,珍爱网婚介费用多少?  建站之家VIP精选网站模板与SEO优化教程整合指南 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。