解决Ajax在页码问题中对于后退机制的破坏

ajax实现点击页码刷新页面内容后,发现如果列表翻了很多页后,当查看过一条记录的详细信息返回目录的时候,不能返回到已经翻过的页码,而要从第一页重新翻,这样做对于用户的友好性交互很不好。

于是我去网上查找,发现了《开发保留标准浏览器功能的AJAX应用程序》这篇文章,按照里面的介绍,摸索出一套解决方案。
实现原理是:每翻一次页,把当前的页码存入碎url的碎片标识中,待客户查看完详细信息后返回到目录,在目录的body的onload事件执行setOptionValue,将碎片的内容获取下来,再执行读取目录的函数;以达到保存翻页信息的功能。

代码如下:

var expectedHash;
//使用URI的碎片标识符部分,创建状态的历史记录;
function makeHistory(newHash)
{
  window.location.hash = newHash; 
 // expectedHash = window.location.hash; 
 // alert(expectedHash);
  return true; 
}
//检查浏览器历史记录中的URI
function handleHistory() 
{  
  if ( window.location.hash != expectedHash ) 
  { 
 //    alert(window.location.hash + "|" + expectedHash);
    expectedHash = window.location.hash; 
    var newoption = expectedHash; 
    setOptionValue( newoption ); 
  } 
  return true; 
}
function pollHash() {
  handleHistory(); 
  //window.setInterval("handleHistory()", 1000); 
  return true; 
}
//获取碎片中的内容,可进行任何操作
function setOptionValue(value) 
{ 
//  var myForm = document.make_history; 
//  var mySelect = myForm.change_year; 
//  mySelect.options[value-1].selected = true; 
    document.getElementById("testDiv").innerHTML = value.replace('#','');
 //   Test(value.replace('#',''));
 //   alert(value.replace('#',''));
  return true; 
}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值