博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
图片懒加载
阅读量:4505 次
发布时间:2019-06-08

本文共 2440 字,大约阅读时间需要 8 分钟。

图片懒加载 

 基于jQuery图片延迟加载插件jQuery.lazyload,使用延迟加载在可提高网页下载速度。在某些情况下,它也能帮助减轻服务器负载。

一.使用方法

  1. 引用jquery和jquery.lazyload.js到你的页面

 

  2. 你必须改变图片的标签。图像的地址必须放在data-original属性上。给懒加载图像一个特定的class(例如:lazy)。这样你可以很容易地进行图像插件捆绑。代码如下:

    HTML:

    js:

$(function() {    $("img.lazy").lazyload();});

    这将使所有 class 为 lazy 的图片将被延迟加载.

二. 设置临界点

  默认情况下图片会出现在屏幕时加载. 如果你想提前加载图片, 可以设置threshold 选项, 设置 threshold 为 200 令图片在距离屏幕 200 像素时提前加载.

$("img.lazy").lazyload({    threshold : 200});

三. 设置事件来触发加载

  你可以使用jQuery事件,例如clickmouseover。也可以使用自定义事件,如sportyfoobar默认情况下是要等到用户向下滚动并且图像出现在视口中时。

  只有当用户点击它们才加载图片:

$("img.lazy").lazyload({    event : "click"});

四. 使用特效

  默认情况下,插件等待图像完全加载并调用show()。你可以使用任何你想要的效果。下面的代码使用fadeIn (淡入效果)。

$("img.lazy").lazyload({    effect : "fadeIn"});

五.针对不启用javaScript的情况

  几乎所有浏览器的 JavaScript 都是激活的. 然而可能你仍希望能在不支持 JavaScript 的客户端展示真实图片. 当浏览器不支持 JavaScript 时优雅降级, 你可以将真实的图片片段                  写在 <noscript> 标签内.

  可以通过 CSS 隐藏占位符.

.lazy {    display: none;}

  在支持 JavaScript 的浏览器中, 你必须在 DOM ready 时将占位符显示出来, 这可以在插件初始化的同时完成.

$("img.lazy").show().lazyload();

六. 图片在容器中

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

$("img.lazy").lazyload({
  container: $("#container"), // 对某容器中的图片实现效果 // container,值为某容器.lazyload默认在拉动浏览器滚动条时生效,这个参数可以让你在拉动某DIV的滚动条时依次加载其中的图片 });

七.加载隐藏的图片

  可能在你的页面上埋藏可很多隐藏的图片. 比如插件用在对列表的筛选, 你可以不断地修改列表中各条目的显示状态. 为了提升性能, Lazy Load 默认忽略了隐藏图片. 如果你想要加载隐藏图片,   请将 skip_invisible 设为 false

$("img.lazy").lazyload({     skip_invisible : false});

八. 参数设置

$("img.lazy").lazyload({  placeholder : "img/grey.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张可见区域外的图片,以避免出现这个问题.});

 

下载插件:

最新版本  和 . 插件已经在 OSX 的 Safari 5.1, Safari 6, Chrome 20, Firefox 12 浏览器上, Windows 的 Chrome 20, IE 8 and IE 9 浏览器上, 以及 iOS5 (iPhone 和 iPad) 的 Safari 5.1 浏览器上测试过.

 

转载于:https://www.cnblogs.com/wangyihong/p/7808771.html

你可能感兴趣的文章
UIWebView 操作
查看>>
非阻赛IO模型
查看>>
Android应用程序签名详解(转载)
查看>>
CentOS7 Failed to start LSB: Bring up/down networking.解决方法
查看>>
360浏览器文档模式升级
查看>>
MongoDB学习笔记(四)
查看>>
bzoj2301 [HAOI2011]Problem b(莫比乌斯反演)
查看>>
C#文件操作-File类
查看>>
winform中Dock的布局规则
查看>>
Java实现主线程等待子线程
查看>>
命令模式(Command)
查看>>
CozyRSS开发记录9-快速实现一个RSS解析器
查看>>
后端程序员之路 21、一个cgi的c++封装
查看>>
ha_innobase::open
查看>>
IIS6架构
查看>>
ELKStack-生产案例项目实战(十一)
查看>>
PHP图形处理函数试题
查看>>
幸运数
查看>>
Golang脱坑指南: goroutine(不断更新)
查看>>
nginx 3.nginx+fastcgi
查看>>