网络编程 
首页 > 网络编程 > 浏览文章

jQuery lazyload 的重复加载错误以及修复方法

(编辑:jimmy 日期: 2025/5/11 浏览:3 次 )
分析代码也可以知道。
最主要的原因是 写在页面上的 <img src="/UploadFiles/2021-04-02/the_big_img_toLoad.jpg">如果想实现原定的效果,则 写在页面上的待加载地址 必须不能是大图片的地址,而我们可以将真正的图片地址数据 存储在alt属性中。
正确的例子如下:
复制代码 代码如下:
<a href="#nogo"><img alt="https://www.jb51.net/comstyles/img200-150-3.jpg" src="/UploadFiles/2021-04-02/spacer.gif"><a href="#nogo"><img alt="https://www.jb51.net/comstyles/img200-150-4.jpg" src="/UploadFiles/2021-04-02/spacer.gif">
对原来的 jquery.lazyload.js我们也需要做一点改动:
复制代码 代码如下:
<script type="text/javascript" src="/UploadFiles/2021-04-02/jquery.min.js"><script type="text/javascript" src="/UploadFiles/2021-04-02/lazyload.js"><script type="text/javascript"> //初始化代码
$(document).ready(function(){
$("#lazy1 img,#lazy2 img").lazyload({
placeholder : "http://sc.jb51.net/style/img/spacer.gif",
effect : "fadeIn"
});
});
</script>

完整实例如下:
复制代码 代码如下:
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>无标题文档</title>
<style type="text/css">
img{ display:block; border:2px solid #ccc; margin:0 0 10px;}
</style>
<script type="text/javascript" src="/UploadFiles/2021-04-02/jquery.min.js"><script type="text/javascript" src="/UploadFiles/2021-04-02/lazyload.js"><script type="text/javascript"> //初始化代码
$(document).ready(function(){
$("#lazy1 img,#lazy2 img").lazyload({
placeholder : "http://qsl.cn/style/img/spacer.gif",
effect : "fadeIn"
});
});
</script>
</head>
<body>
<div style=" height:900px; width:400px; background:#eee;">
<a href="#nogo"><img src="/UploadFiles/2021-04-02/img200-150-2.jpg">第一屏高度为900px,滚动到下面的时候,相应图片才开始加载
</div>
<div id="lazy1" style="width:350px; margin-bottom:340px;">
<a href="#nogo"><img alt="http://www.titan24.com/comstyles/ad400-300.jpg" src="/UploadFiles/2021-04-02/spacer.gif"><a href="#nogo"><img alt="http://www.titan24.com/comstyles/img200-150-1.jpg" src="/UploadFiles/2021-04-02/spacer.gif"><a href="#nogo"><img alt="http://www.titan24.com/comstyles/img200-150-2.jpg" src="/UploadFiles/2021-04-02/spacer.gif"></div>
<div id="lazy2" style="width:350px;">
<a href="#nogo"><img alt="http://www.titan24.com/comstyles/img200-150-3.jpg" src="/UploadFiles/2021-04-02/spacer.gif"><a href="#nogo"><img alt="http://www.titan24.com/comstyles/img200-150-4.jpg" src="/UploadFiles/2021-04-02/spacer.gif"><a href="#nogo"><img alt="http://www.titan24.com/comstyles/img560-300-1.jpg" src="/UploadFiles/2021-04-02/spacer.gif"><a href="#nogo"><img alt="http://www.titan24.com/comstyles/img560-300-2.jpg" src="/UploadFiles/2021-04-02/spacer.gif"><a href="#nogo"><img alt="http://www.titan24.com/comstyles/img560-300-3.jpg" src="/UploadFiles/2021-04-02/spacer.gif"><a href="#nogo"><img alt="http://www.titan24.com/comstyles/img560-300-4.jpg" src="/UploadFiles/2021-04-02/spacer.gif"></div>
</body>
</html>

测试可知 是真正的按需加载。而不是像之前,先加载了,滚动到相应位置 还又加载了一次。
Firebug的眼睛还是雪亮的。
上一篇:jquery.cvtooltip.js 基于jquery的气泡提示插件
下一篇:JQuery 选择和过滤方法代码总结
一句话新闻
Windows上运行安卓你用过了吗
在去年的5月23日,借助Intel Bridge Technology以及Intel Celadon两项技术的驱动,Intel为PC用户带来了Android On Windows(AOW)平台,并携手国内软件公司腾讯共同推出了腾讯应用宝电脑版,将Windows与安卓两大生态进行了融合,PC的使用体验随即被带入到了一个全新的阶段。
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 网站地图 SiteMap