解决Ajax在页码问题中对于后退机制的破坏
2016-03-16 00:19
351 查看
ajax实现点击页码刷新页面内容后,发现如果列表翻了很多页后,当查看过一条记录的详细信息返回目录的时候,不能返回到已经翻过的页码,而要从第一页重新翻,这样做对于用户的友好性交互很不好。
于是我去网上查找,发现了《开发保留标准浏览器功能的AJAX应用程序》这篇文章,按照里面的介绍,摸索出一套解决方案。
实现原理是:每翻一次页,把当前的页码存入碎url的碎片标识中,待客户查看完详细信息后返回到目录,在目录的body的onload事件执行setOptionValue,将碎片的内容获取下来,再执行读取目录的函数;以达到保存翻页信息的功能。
代码如下:
于是我去网上查找,发现了《开发保留标准浏览器功能的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; }
相关文章推荐
- Centos 7 开启端口
- 作业3
- Mac软件推荐
- android获取APK签名信息及MD5指纹
- C语言杂谈(二)自增运算符++与间接访问运算符*的结合关系和应用模式
- iOS企业开发者计划付费后的坑
- TCP接收/发送滑动窗口与内核接收/发送缓冲区之间的关系
- MySQL MERGE存储引擎 简
- BZOJ 4338 BJOI2015 糖果
- VMWARE虚拟机无法上网的解决方法
- java 求二叉树最大深度算法
- 从域名锁定该网站所在城市
- 整合百度推送碰到的问题
- 第三章 垃圾回收的一些概念
- 整合百度推送碰到的问题
- 稀疏矩阵的转置
- 第一篇
- Spring定时任务的几种实现
- 完整的省市县三级联动
- RMAN之恢复控制文件