我们做过微信的应该都知道,微信自带的返回上一页,就是重新打开页面。并不是返回历史页面。我们PC端的浏览器是返回历史页面。点击返回页面之后 上一个页面的scrollTop还是之前没有进入新页面的位置。
我看了下京东的微信网站。果然和我想到的方法一样。利用sessionStorage HTML5本地存储 进行存储位置scrollTop以及加载了多少次ajax次数 微信返回上一页(当前页面)之后。就会onload一下。设置最后一次scrollTop的值。以及一次性通过ajax传递之前加载的次数size渲染页面。这样在微信里面就可以实现和PC一样的效果。
代码如下:
var c=0,
matter=el(document,".matter",1);
window.οnlοad=function(){
var a=b=null;
if(window.sessionStorage){
a=parseInt(sessionStorage.getItem("top"));
b=parseInt(sessionStorage.getItem("size"));
//6是AJAX 每次请求多少个dd
num=6*b;
c=b?b:0;
// ajax渲染
for (var i = 0; i < num; i++){
var dd=document.createElement("dd")
dd.innerHTML="魔力魔力魔力魔力魔力魔力魔力魔...
收获佣金¥106.00
点击量 125"+i+"
"
matter.querySelector("dl").appendChild(dd);
};
alert(a);
document.body.scrollTop=a;
}
}
window.οnscrοll=function(){
var tops=document.body.scrollTop,
height=document.documentElement.scrollHeight,
scrollbottom=height-_height-tops;
console.log("top:"+tops+"height:"+height+"scrollbottom:"+scrollbottom+"_height"+_height);
if(window.sessionStorage){
sessionStorage.setItem("top",tops);
sessionStorage.setItem("size",c);
}
if(scrollbottom==0||scrollbottom==-1){
$.ajax({
//type: 'GET',
//url: './',
//data: { size: 6 },
//dataType: 'json',
//timeout: 300,
beforeSend:function(){
$(".panle").removeClass("pon");
},
success: function(data){
$(".panle").addClass("pon");
for (var i = 0; i < 6; i++){
var dd=document.createElement("dd")
dd.innerHTML="魔力魔力魔力魔力魔力魔力魔力魔...
收获佣金¥106.00
点击量 125"+i+"
"
matter.querySelector("dl").appendChild(dd);
};
//正常状态请求了多少AJAX
c++;
},
error: function(xhr, type){
alert('Ajax error!')
}
})
}
}
代码是我之前一个项目上的demo代码。重点就是 sessionStorage 对了 说道sessionStorage 我说一下为什么没用localStorage localStorage是永久的。这样就会有一个问题,当前退出了这个网站之后 下次打开网站 进入这个页面。那么你最后一次离开的值依然存在在本地存储里面。用户体验就不好了。sessionStorage就不错,因为是临时性的。关闭了网站,下次进入的时候就是重新开始保存计算。
定义了一个全局变量c。还有a,b是获取sessionStorage里面的scrollTop 和ajax的值。onscroll的时候记录这两个值实时保存到sessionStorage里面。每次AJAX请求成功了,就c++一下。
c=b?b:0 这个意思就是 如果请求了ajax c的值就是等于b否则等于0.这样做因为c是全局变量,每次重新打开页面它都会等于0的.
知道了最后一次scrollTop和size OK了 我们就直接AJAX一次行渲染出来结构。在设置scrollTop位置。最好是先渲染再设置。反过来scrollTop会出现BUG。因为页面结构没有这么多。位置停留会出现在最底部。并没有到最后一次的位置。加载之后 结构躲起来了,页面高度也有了。这样scrollTop就可以好好设置。
QQ 295989501 欢迎一起交流学习