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

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

(编辑:jimmy 日期: 2026/5/7 浏览: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 选择和过滤方法代码总结
一句话新闻
高通与谷歌联手!首款骁龙PC优化Chrome浏览器发布
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 站点导航 SiteMap