`
jsczxy2
  • 浏览: 1256022 次
  • 性别: Icon_minigender_1
  • 来自: 常州
文章分类
社区版块
存档分类
最新评论

jquery页面图片延迟加载框架

阅读更多

在浏览有些网站时,发现图片是在下拉滚动条时才加载,这是一个很不错的用户体验。这一效果是通过JavaScript 编写的 jQuery 插件实现的,它可以延迟加载长页面中的图片. 在浏览器可视区域外的图片不会被载入, 直到用户将页面滚动到它们所在的位置. 这与图片预加载的处理方式正好是相反的.在包含很多大图片长页面中延迟加载图片可以加快页面加载速度. 浏览器将会在加载可见图片之后即进入就绪状态. 在某些情况下还可以帮助降低服务器负担. 有些WordPress主题也具备了此功能。

目前我用的这个热点新闻主题由于有缩略图功能所以也试着加上看看效果如何。这里把这一功能应用到WordPress主题方法说一下,其实很简单,首先下载jquery.lazyloa.js,放到主题目录中,然后在header.php模板文件</head>标签前添加如下代码:

  1. <script type="text/javascript" src="<?php bloginfo('template_directory');?>/js/jquery.lazyload.js"></script>
  2. <script type="text/javascript">
  3. $(function() {
  4. $("img").lazyload({
  5. effect : "fadeIn"
  6. });
  7. });
  8. </script>

其中img是延迟加载所有图片,也可以根据不同模板作相应改动,比如我这个主题,可以改成#post img,这样只延迟加载#post 容器内的图片,否则可能影响到侧边图片的加载,主要是留言者头像可能会最后加载;

fadeIn是图片显示效果

这样基本就可以了!

如果上面的功能可能没有达到你的要求,还有几个选项可供设置。

可以设置阀值来控制 灵敏度

  1. $(“img”).lazyload({ threshold : 200 });  

把阀值设置成200 意思就是当图片没有看到之前先load 200像素。当然了你也可以通过设置占位符图片和自定事件来触发加载图片事件

  1. $("img").lazyload({   
  2. placeholder : "img/grey.gif",   
  3. event : "click"  
  4. });  

还可以通过定义effect 参数来定义一些图片显示效果

  1. $("img").lazyload({   
  2. placeholder : "img/grey.gif",   
  3. effect : "fadeIn"  
  4. });  

事件触发加载,事件可以是任何 jQuery 时间, 如: click 和 mouseover. 你还可以使用自定义的事件, 如: sporty 和 foobar. 默认情况下处于等待状态, 直到用户滚动到窗口上图片所在位置. 在灰色占位图片被点击之前阻止加载图片, 你可以这样做:

  1. $("img").lazyload({   
  2. placeholder : "img/grey.gif",   
  3. event : "click"  
  4. });  

延迟加载图片,Lazy Load 插件的一个不完整的功能, 但是这也能用来实现图片的延迟加载. 下面的代码实现了页面加载完成后再加载. 页面加载完成 5 秒后, 指定区域内的图片会自动进行加载.

  1. $(function() {   
  2. $("img:below-the-fold").lazyload({   
  3. placeholder : "img/grey.gif",   
  4. event : "sporty"  
  5. });   
  6. });   
  7. $(window).bind("load"function() {   
  8. var timeout = setTimeout(function() {$("img").trigger("sporty")}, 5000);   
  9. });  

图片在容器里面你可以将插件用在可滚动容器的图片上, 例如带滚动条的 DIV 元素. 你要做的只是将容器定义为 jQuery 对象并作为参数传到初始化方法里面.

CSS

  1. #container {   
  2. height600px;   
  3. overflowscroll;   
  4. }  

JavaScript 代码:

  1. $("img").lazyload({   
  2. placeholder : "img/grey.gif",   
  3. container: $("#container")   
  4. });  

当图片不顺序排列,滚动页面的时候, Lazy Load 会循环为加载的图片. 在循环中检测图片是否在可视区域内. 默认情况下在找到第一张不在可见区域的图片时停止循环. 图片被认为是流式分布的, 图片在页面中的次序和 HTML 代码中次序相同. 但是在一些布局中, 这样的假设是不成立的. 不过你可以通过 failurelimit 选项来控制加载行为.

  1. $("img").lazyload({   
  2. failurelimit : 10   
  3. });  

下载地址: sourceminified or packed

分享到:
评论

相关推荐

    基于jQuery的图片延迟加载功能的实现

    :图片延迟加载技术能够加快页面下载速度,减轻服务器的负荷,提高用户体验。图片延迟加载技术在各种js框架都 得到一定程度的实现。本文详细介绍了通过使用jQuery框架实现图片延迟加载功能。

    jQuery lazyLoad图片延迟加载插件的优化改造方法分享

    jQuery lazyLoad.js插件 是一款基于jquery框架,可以“实现”图片延迟加载的插件

    超实用的jQuery代码段

    超实用的jQuery代码段精选近350个jQuery代码段,涵盖页面开发中绝大多数要点、技巧与方法,堪称史上最实用的jQuery代码参考书,可以视为网页设计与网站建设人员的好帮手。《超实用的jQuery代码段》的代码跨平台、跨...

    在JavaScript应用中使用RequireJS来实现延迟加载

    通常开发者会通过JQuery、Knockout、Underscore...在这篇文章里,我将解释 RequireJS框架如何帮助应用开发者写出更加模块化的代码,以及它是如何通过延迟加载JavaScript文件来提高应用性能的。 开始的部分我们先不用R

    在JavaScript应用中实现延迟加载的方法

    通常开发者会通过JQuery、Knockout、Underscore...在这篇文章里,我将解释RequireJS框架如何帮助应用开发者写出更加模块化的代码,以及它是如何通过延迟加载JavaScript文件来提高应用性能的。  开始的部分我们先不用R

    前端项目-jquery.lazyloadxt.zip

    前端项目-jquery.lazyloadxt,Lazy Load XT是一个面向移动的、快速可扩展的jquery插件,用于延迟加载图像、视频和其他媒体,内置jquery mobile框架支持。它通过只加载可见的媒体元素来提高网站的性能,折叠下的元素在...

    jQM-MVC-Lazy-Loader:用于延迟加载模块的 jQuery Mobile 的超轻量级 MVC。 “app”对象上有一些辅助方法来帮助 UI 开发

    ##Purpose 轻量级 jQuery Mobile MVC-ish 延迟加载库。 使项目创建快速简便。 延迟加载控制器和视图。 模型留给开发人员。 辅助方法提供快速简便的 UI 功能。 ####Notes 这并不是一个包罗万象的框架(它只有 300...

    jquery插件使用方法大全

    要等到页面全部加载完毕才执行,注意是全部加载,包括dom,图片等其它资源。 而$(document).ready(function(){ alert&#40;"hello"&#41;; });(1) 当dom加载完就可以执行了。 代码1同时做到表现和逻辑分离。并且可以在...

    H-ui.admin 前端框架

    H-ui.admin是用H-ui前端框架开发的轻量级网站后台模版 ...│ Echo.js 图片延迟加载插件 │ colpick.js 颜色插件 │ handlebars.js js模版引擎 │ waterfall.min.js 瀑布流插件 └─temp 测试数据、图片

    pjscrape:一个用 Javascript 编写的网页抓取框架,使用 PhantomJS 和 jQuery

    pjscrape是一个框架,适用于任何想要使用 Javascript 和进行网页抓取的命令行工具的人。 专为构建,它允许您从命令行在完全呈现、启用 Javascript 的上下文中抓取页面,无需浏览器。 依赖关系 特征 客户端、基于 ...

    jQuery的强密码插件PWChecker.zip

    Power PWChecker 是一个用来确保用户输入了安全... JavaScript图像延迟加载库Echo.js386 Echo 是一个独立的 JavaScript 懒加载图像的工具,快速、体积小(不足1k)和使用 HTML5 的 data- 属性。Echo 支持 IE8 。 ...

    meteor-lazyload-xt:Lazy load XT 是一个用于图像、视频和其他媒体的 jQuery 插件

    延迟加载 XT jQuery 插件面向移动、快速且可扩展的 jQuery 插件,用于延迟加载图像/视频,内置 jQueryMobile 框架支持。 目前已在 IE 6-11、Chrome 1-31、Firefox 1.5-27.0、Safari 3-7、Opera 10.6-18.0、iOS 5-7、...

    javaweb网上淘书吧源码

    该项目是一个二手书交易网站,提供二手书上架、交易、评价等功能,分为买家前台、卖家前台、管理后台三部分。买家前台提供二手书查询、购买下单等功能;...8. 数据库读写分离、图片延迟加载等技术使用 该项目实现了一个二

    H-ui.admin_v2.3.1

    根目录 ...) ...│ robots.txt 搜索引擎爬虫配置文件 ...│ Echo.js 图片延迟加载插件 │ colpick.js 颜色插件 │ handlebars.js js模版引擎 │ waterfall.min.js 瀑布流插件 └─temp 测试数据、图片

    Webiness:轻量级PHP框架-开源

    Webiness广泛使用延迟加载技术,因此,在大多数情况下,它比其他框架要快。 它可以用于Web应用程序的快速原型制作。 Webiness与jQuery集成在一起,它具有一组支持AJAX的功能以及他自己的用于前端开发的轻量级CSS...

    hugo-theme-stack:为博客作者设计的卡片式Hugo主题

    延迟加载图像 暗模式 本地搜寻 集成 存档页面模板 完全本机JavaScript,不使用jQuery或任何其他框架 没有CSS框架,请​​保持简洁和最小化 正确裁剪的缩略图 小节支持 要求 必须使用Hugo≥0.78.0 。 如果要执行以下...

    Phonegap-:phonegap 应用程序

    RhoConnect.js 积极使用来自 jQuery API 的延迟/承诺对象。 所有异步结果都作为返回的promise对象的done(..)方法调用的参数值返回。 入门 加载 rhoconnect.js 库: &lt;html&gt; &lt;head&gt; &lt;script type=...

    mobile-framework:这是用于移动框架分配的 Web 端

    移动框架这是用于移动框架分配的 Web 端对于此作业,您将使用 HTML、CSS 和 Javascript 构建自己的应用程序框架。 构建一个包含三个屏幕的 HTML 文件。 无需 jQuery 即可构建此应用程序。 处理 300ms 延迟,以支持旧...

Global site tag (gtag.js) - Google Analytics