如何让浏览器支持jquery ajax load 前进、后退功能


Posted in Javascript onJune 12, 2014

一般在做 ajax load 的时候,很多人都不会考虑到需要浏览器支持前进后退功能,因为大部分人都不知道可以实现。

最近遇到这个问题,经过一小段研究,发现github已经有现成的开源工具使用,主要实现原理是利用html的锚点,即<a href="#xxx">

主要demo代码如下:

html

<ul> 
<li><a href="#ttt">ttttttttttttttt</a></li> 
<li><a href="#aaa">aaaaaaaaaaaaaaa</a></li> 
<li><a href="#bbb">bbbbbbbbbbbbbbb</a></li> 
<li><a href="#eee">eeeeeeeeeeeeeee</a></li> 
<li><a href="#mmm">mmmmmmmmmmmmmmm</a></li> 
</ul> 
<div id="showdiv" style="width: 500px; height: 500px; border: 1px groove #e3e7ea;">default content</div>

js
<script type="text/javascript"> 
$(function() { 
// 这里是共用的位置,通过state参数做操作 
$.History.bind(function(state){ 
$('#showdiv').load('action/'+state+'.html'); 
}); 
// 这里是对某个链接做特殊操作 
$.History.bind('bbb',function(state){ 
alert('点击了 bbb 链接,这是对 bbb 链接特殊处理位置'); 
}); 
}); 
</script>

相关问题:

state 参数:即超链接标签href="#xxx"中的xxx值。

执行顺序:先执行特殊操作,再执行共用操作。

Javascript 相关文章推荐
js动画(animate)简单引擎代码示例
Dec 04 Javascript
js 获取和设置css3 属性值的实现方法
May 06 Javascript
javascript完美拖拽的实现方法
Sep 29 Javascript
javascript实现存储hmtl字符串示例
Apr 25 Javascript
使用jquery操作session方法分享
Jan 22 Javascript
jquery实现的省市区三级联动
Apr 02 Javascript
javascript设计模式--策略模式之输入验证
Nov 27 Javascript
js html5 css俄罗斯方块游戏再现
Oct 17 Javascript
JavaScript自定义分页样式
Jan 17 Javascript
javascript算法之二叉搜索树的示例代码
Sep 12 Javascript
深入浅析Node.js 事件循环、定时器和process.nextTick()
Oct 22 Javascript
javascript的setTimeout()使用方法总结
Nov 20 Javascript
js创建一个input数组并绑定click事件的方法
Jun 12 #Javascript
javascript实现阻止iOS APP中的链接打开Safari浏览器
Jun 12 #Javascript
jQuery实现复选框全选/取消全选/反选及获得选择的值
Jun 12 #Javascript
深入理解javascript中的立即执行函数(function(){…})()
Jun 12 #Javascript
Javascript封装DOMContentLoaded事件实例
Jun 12 #Javascript
自己封装的javascript事件队列函数版
Jun 12 #Javascript
jquery动态添加删除一行数据示例
Jun 12 #Javascript
You might like
全国FM电台频率大全 - 8 黑龙江省
2020/03/11 无线电
CentOS 6.2使用yum安装LAMP以及phpMyadmin详解
2013/06/17 PHP
PHP 实现代码复用的一个方法 traits新特性
2015/02/22 PHP
JavaScript高级程序设计 阅读笔记(十四) js继承机制的实现
2012/08/14 Javascript
jquery根据属性和index来查找属性值并操作
2014/07/25 Javascript
JavaScript实现继承的4种方法总结
2014/10/16 Javascript
ECMAScript 6即将带给我们新的数组操作方法前瞻
2015/01/06 Javascript
在JavaScript中如何解决用execCommand(
2015/10/19 Javascript
jQuery插件pagination实现无刷新分页
2016/05/21 Javascript
jQuery自定义图片缩放拖拽插件imageQ实现方法(附demo源码下载)
2016/05/27 Javascript
JavaScript进阶练习及简单实例分析
2016/06/03 Javascript
Bootstrap零基础入门教程(三)
2016/07/18 Javascript
浅谈JS继承_寄生式继承 &amp; 寄生组合式继承
2016/08/16 Javascript
seajs模块之间依赖的加载以及模块的执行
2016/10/21 Javascript
js实现百度地图定位于地址逆解析,显示自己当前的地理位置
2016/12/08 Javascript
Bootstrap的modal拖动效果
2016/12/25 Javascript
利用node.js实现反向代理的方法详解
2017/07/24 Javascript
Vue波纹按钮组件制作
2018/04/30 Javascript
Vue 自适应高度表格的实现方法
2020/05/13 Javascript
[00:09]DOTA2新版本PA至宝特效动作展示
2014/11/19 DOTA
Python中几个比较常见的名词解释
2015/07/04 Python
python实现百万答题自动百度搜索答案
2018/01/16 Python
python利用wx实现界面按钮和按钮监听和字体改变的方法
2019/07/17 Python
opencv导入头文件时报错#include的解决方法
2019/07/31 Python
利用Python实现Excel的文件间的数据匹配功能
2020/06/16 Python
python代码中怎么换行
2020/06/17 Python
Python3爬虫里关于代理的设置总结
2020/07/30 Python
什么是数组名
2012/05/10 面试题
写出SQL四条最基本的数据操作语句(DML)
2012/12/12 面试题
心理健康心得体会
2014/01/02 职场文书
摄影专业毕业生求职信
2014/03/13 职场文书
高中英语演讲稿范文
2014/04/24 职场文书
副总经理岗位职责范本
2014/09/30 职场文书
公司人事任命通知
2015/04/20 职场文书
美德少年事迹材料(2016推荐版)
2016/02/25 职场文书
2019年亲子运动会口号
2019/10/11 职场文书