分析代码也可以知道。
最主要的原因是 写在页面上的 <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的眼睛还是雪亮的。
最主要的原因是 写在页面上的 <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的眼睛还是雪亮的。
标签:
lazyloa,重复加载
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
狼山资源网 Copyright www.pvsay.com
暂无“jQuery lazyload 的重复加载错误以及修复方法”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。