• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >JavaScript > jquery实现异步加载图片(懒加载图片一种方式)

jquery实现异步加载图片(懒加载图片一种方式)

作者:专注前端30年 字体:[增加 减小] 来源:互联网 时间:2017-05-11

专注前端30年通过本文主要向大家介绍了jquery ajax异步请求,jquery ajax 异步,jquery ajax异步刷新,jquery异步提交表单,jquery 异步请求等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

首先将插件在jq后面引入

 (function($) { 
        // alert($.fn.scrollLoading); 
        $.fn.scrollLoading = function(options) { 
          var defaults = { 
            attr: "data-url" 
          }; 
          var params = $.extend({}, defaults, options || {}); 
          params.cache = []; 
          $(this).each(function() { 
            var node = this.nodeName.toLowerCase(), 
              url = $(this).attr(params["attr"]); 
            if(!url) { 
              return; 
            } 
            var data = { 
              obj: $(this), 
              tag: node, 
              url: url 
            }; 
            params.cache.push(data); 
          }); 
 
          var loading = function() { 
            var st = $(window).scrollTop(), 
              sth = st + $(window).height(); 
            $.each(params.cache, function(i, data) { 
              var o = data.obj, 
                tag = data.tag, 
                url = data.url; 
              if(o) { 
                post = o.position().top; 
                posb = post + o.height(); 
                if((post > st && post < sth) || (posb > st && posb < sth)) { 
                  if(tag === "img") { 
                    o.attr("src", url); 
                  } else { 
                    o.load(url); 
                  } 
                  data.obj = null; 
                } 
              } 
            }); 
            return false; 
          }; 
 
          loading(); 
          $(window).bind("scroll", loading); 
        }; 
      })(jQuery);
</div>

然后在底部初始化

 $(document).ready(function () { 
    //实现图片慢慢浮现出来的效果 
    $("img").load(function () { 
      //图片默认隐藏  
      $(this).hide(); 
      //使用fadeIn特效  
      $(this).fadeIn("5000"); 
    }); 
    // 异步加载图片,实现逐屏加载图片 
    $(".scrollLoading").scrollLoading();  
  });
</div>

需要修改img标签为

<img class="scrollLoading" data-url="image/logo.jpg" src="images/load.gif" /> 
</div>

data-url表示将要异步加载的图片,src表示首先加载的图片(一般会是小图片,或者是一个动画,网页中全部的src链接同一个图片,这样网页就加载快好多,这个时候再异步的加载要加载的图片,也就现在要说的功能)

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

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • jquery实现异步加载图片(懒加载图片一种方式)
  • ajax异步请求详解

相关文章

  • 2017-05-11node.js入门教程之querystring模块的使用方法
  • 2017-05-11利用Vue v-model实现一个自定义的表单组件
  • 2017-05-11js常用DOM方法详解
  • 2017-05-11javascript实现table单元格点击展开隐藏效果(实例代码)
  • 2017-05-11Web纯前端“旭日图”实现元素周期表
  • 2017-05-11vue.js学习笔记:如何加载本地json文件
  • 2017-05-11原生js实现倒计时--2018
  • 2017-05-11Javascript实现数组中的元素上下移动
  • 2017-05-11js 性能优化之算法和流程控制
  • 2017-05-11基于JQuery的购物车添加删除以及结算功能示例

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 微信小程序五星评分效果实现代码
    • vue日期组件 支持vue1.0和2.0
    • 基于vuejs实现一个todolist项目
    • js设置光标始终在文本最后
    • 常用的javascript设计模式
    • HTML5+jQuery实现搜索智能匹配功能
    • windows下vue-cli及webpack搭建安装环境
    • JS仿JQuery选择器功能
    • jQuery中 bind的用法简单介绍
    • bootstrap table配置参数例子

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有