JavaScript仿淘宝页面图片滚动加载及刷新回顶部的方法解析
淘宝图片处理讨论
淘宝网页面很大,但是打开速度很快。其对图片处理是运用了滚动加载,就是滚动轴滚到哪里,图片在哪里加载。但是你想查看他的源代码,那要费九牛二虎之力吧,因为他们代码压缩合并做的很好!因为图片是滚动加载的,初始化的时候图片不加载,那么当你在页面底部刷新页面的时候,底部的页面通常不会加载出来,淘宝网的做法貌似是(因为我没有看他们的源代码,只是凭操作),刷新让页面回到顶部。
模仿淘宝,做滚动图片加载
这里想到了三种方法:
1.javascript懒加载之可视区域加载
<!DOCTYPEhtml>
<htmllang="en">
<head>
<metacharset="UTF-8">
<title>haorooms前端博客-可视区域加载之javascript</title>
<style>
img{width:100%;margin-bottom:30px;min-height:400px;background-color:#ddd;}
</style>
</head>
<body>
<imghaoroomslazyload="Chrysanthemum.jpg"src="">
<imghaoroomslazyload="Desert.jpg"src="">
<imghaoroomslazyload="Hydrangeas.jpg"src="">
<imghaoroomslazyload="Koala.jpg"src="">
<imghaoroomslazyload="Lighthouse.jpg"src="">
<imghaoroomslazyload="Penguins.jpg"src="">
<imghaoroomslazyload="Tulips.jpg"src="">
<script>
varimgNum=document.getElementsByTagName('img').length;
varimgObj=document.getElementsByTagName("img");
varl=0;
window.onscroll=function(){
varseeHeight=document.documentElement.clientHeight;
varscrollTop=document.documentElement.scrollTop||document.body.scrollTop;
for(vari=l;i<imgNum;i++){
if(imgObj[i].offsetTop<seeHeight+scrollTop){
console.log(imgObj[i].getAttribute("src"));
console.log(imgObj[i].src);
if(imgObj[i].getAttribute("src")==""){
imgObj[i].src=imgObj[i].getAttribute("haoroomslazyload");
}
}
if(imgObj[i].offsetTop>seeHeight+scrollTop){
l=i;
break;
}
}
}
</script>
大家注意看我的两个console输出,console.log(imgObj[i].src);获取的是整个浏览器地址!
2.jquery懒加载之可视区域加载
上面的js用jquery翻译版!
varl=0
//js方法翻译版
$(window).bind("scroll",function(event){
for(vari=l;i<$("img").length;i++){
if($("img").eq(i).offset().top<parseInt($(window).height())+parseInt($(window).scrollTop())){
if($("img").eq(i).attr("src")==""){
varlazyloadsrc=$('img').eq(i).attr("haoroomslazyload");
$("img").eq(i).attr("src",lazyloadsrc);
}
}
if($("img").eq(i).offset().top>parseInt($(window).height())+parseInt($(window).scrollTop())){
l=i;
break;
}
}
});
3.可视区域加载延伸
例如一个动画效果,或者一个canvas图片,我想达到的效果是,初始进来不加载,当滚动到这个动画或者图表上面的时候,进行加载,那么我们就可以根据上面的代码进行如下改进:
$(window).bind("scroll",function(event){
//窗口的高度+看不见的顶部的高度=屏幕低部距离最顶部的高度
varthisButtomTop=parseInt($(window).height())+parseInt($(window).scrollTop());
varthisTop=parseInt($(window).scrollTop());//屏幕顶部距离最顶部的高度
varPictureTop=parseInt($("你的要滚动加载的ID").offset().top);
if(PictureTop>=thisTop&&PictureTop<=thisButtomTop){
//$("#你的要滚动加载的ID").attr("src",$("#你的要滚动加载的ID").attr("haoroomslazyload"));
//此处可以执行你的加载函数,加载函数由原来的document.ready中,移到这里来!
}
})
刷新回顶部
当我们做了可视区域加载的时候,通常让其刷新回到顶部。像淘宝那样。刷新回顶部。
我不知道淘宝网是如何做的。刷新回顶部,我用到的是onbeforeunload事件。
onbeforeunload与onunload事件,onunload和onbeforeunload都是在刷新或关闭时调用,可以在<script>脚本中通过window.onunload来指定或者在<body>里指定。区别在于onbeforeunload在onunload之前执行,它还可以阻止onunload的执行。
Onbeforeunload也是在页面刷新或关闭时调用,Onbeforeunload是正要去服务器读取新的页面时调用,此时还没开始读取;而onunload则已经从服务器上读到了需要加载的新的页面,在即将替换掉当前页面时调用。Onunload是无法阻止页面的更新和关闭的。而Onbeforeunload可以做到。
1.页面加载时只执行onload
2.页面关闭时先执行onbeforeunload,最后onunload
3.页面刷新时先执行onbeforeunload,然后onunload,最后onload。
刷新回顶部就是用这个事件,可以这么写。
window.onbeforeunload=function(){$(window).scrollTop(0);}
当网站所有的图片都用了可是区域加载,css和js都合并压缩了,那我们的网站速度和性能会提升很多!
假如你想做成淘宝那样,你可以改进一下代码。
其实延迟加载的思路就是先把图片放在一个data-src或者一个属性中,当页面滑动到可视区域内时,把存起来的图片地址赋值给src就可以了。
这里我就不罗列代码了。