当前位置:编程学习 > JS >>

图片延迟加载jQuery代码

图片延迟加载jquery代码

先来看一款jquery图片延迟加载实例代码

<script type="text/网页特效" src="/网页特效/jquery.lazyload.js"></script>
<script>
$(function() {         
     $("img:below-the-fold").lazyload({
         placeholder : "img/grey.gif",
         event : "sporty"
     });
 });
 $(window).bind('load', function() {
     var timeout = settimeout(function() { $("img").trigger("sporty") }, 5000);
 });  
 
 </script>


下面详细看看延迟加载详细说明
<script type="text/javascript">
$(function() {
$("img").lazyload({
effect : "fadein"
});
});
</script>
其中img是延迟加载所有图片,也可以根据不同模板作相应改动,比如我这个主题,可以改成#post img,这样只延迟加载#post 容器内的图片,否则可能影响到侧边图片的加载,主要是留言者头像可能会最后加载;

fadein是图片显示效果

这样基本就可以了!

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

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

$("img").lazyload({ threshold : 200 });
把阀值设置成200 意思就是当图片没有看到之前先load 200像素。当然了你也可以通过设置占位符图片和自定事件来触发加载图片事件

$("img").lazyload({
placeholder : "img/grey.gif",
event : "click"
});
还可以通过定义effect 参数来定义一些图片显示效果

$("img").lazyload({
placeholder : "img/grey.gif",
effect : "fadein"
});
事件触发加载,事件可以是任何 jquery 时间, 如: click 和 mouseo教程ver. 你还可以使用自定义的事件, 如: sporty 和 foobar. 默认情况下处于等待状态, 直到用户滚动到窗口上图片所在位置. 在灰色占位图片被点击之前阻止加载图片, 你可以这样做:

$("img").lazyload({
placeholder : "img/grey.gif",
event : "click"
});
延迟加载图片,lazy load 插件的一个不完整的功能, 但是这也能用来实现图片的延迟加载. 下面的代码实现了页面加载完成后再加载. 页面加载完成 5 秒后, 指定区域内的图片会自动进行加载.

$(function() {
$("img:below-the-fold").lazyload({
placeholder : "img/grey.gif",
event : "sporty"
});
});
$(window).bind("load", function() {
var timeout = settimeout(function() {$("img").trigger("sporty")}, 5000);
});
图片在容器里面你可以将插件用在可滚动容器的图片上, 例如带滚动条的 div 元素. 你要做的只是将容器定义为 jquery 对象并作为参数传到初始化方法里面.

css教程

#container {
height: 600px;
overflow: scroll;
}
javascript 代码:

$("img").lazyload({
placeholder : "img/grey.gif",
container: $("#container")
});
当图片不顺序排列,滚动页面的时候, lazy load 会循环为加载的图片. 在循环中检测图片是否在可视区域内. 默认情况下在找到第一张不在可见区域的图片时停止循环. 图片被认为是流式分布的, 图片在页面中的次序和 html 代码中次序相同. 但是在一些布局中, 这样的假设是不成立的. 不过你可以通过 failurelimit 选项来控制加载行为.

$("img").lazyload({
failurelimit }

一款js图片延时加载代码

<script>
function   getwidth(objname)   {
    if(eval(objname+ ".readystate ")   !=   'complete '){
        settimeout( "getwidth( ' "+objname+ " ') ",10)
    }else   {
    alert(   eval(objname+ ".width ")   );
    }
}
</script>
<img   name=img1   src=163.gif   onclick= "this.src= '/pic_rf/rf_show3.jpg ';getwidth(this.name) ">


到http://down.zzzyk.com/down/code/jquery/2010/0812/20179.html下载jquery.lazyload.js插件

补充:网页制作,js教程 
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,