详解HTML5之pushstate、popstate操作history,无刷新改变当前url


Posted in HTML / CSS onMarch 15, 2017

一、认识window.history

window.history表示window对象的历史记录,是由用户主动产生,并且接受javascript脚本控制的全局对象。window对象通过history对象提供对览器历史记录的访问能力。它暴露了一些非常有用的方法和属性,让你在历史记录中自由前进和后退。

1、历史记录的前进和后退

在历史记录中后退,可以这么做:

window.history.back();

这就像用户点击浏览器的后退按钮一样。

类似的,你可以前进,就像在浏览器中点击前进按钮,像这样:

window.history.forward();

2、移动到指定历史记录点

通过指定一个相对于当前页面位置的数值,你可以使用go()方法从当前会话的历史记录中加载页面(当前页面位置索引值为0,上一页就是-1,下一页为1)。

要后退一页(相当于调用back()):

window.history.go(-1);

向前移动一页(相当于调用forward()):

window.history.go(1);

类似的,传递参数“2”,你就可以向前移动2个记录点。你可以查看length属性值,了解历史记录栈中一共有多少个记录点:

window.history.length;

二、修改历史记录点

HTML5的新API扩展了window.history,使历史记录点更加开放了。可以存储当前历史记录点、替换当前历史记录点、监听历史记录点,下面逐一简要说明一下。

1、存储当前历史记录点

存储的方式类似于数组的入栈(Array.push()),在window.history里新增一个历史记录点,例如:

// 当前的url为:http://qianduanblog.com/index.html
var json={time:new Date().getTime()};
// @状态对象:记录历史记录点的额外对象,可以为空
// @页面标题:目前所有浏览器都不支持
// @可选的url:浏览器不会检查url是否存在,只改变url,url必须同域,不能跨域
window.history.pushState(json,"","http://qianduanblog.com/post-1.html");

执行了pushState方法后,页面的url地址为http://qianduanblog.com/post-1.html。

2、替换当前历史记录点

window.history.replaceState和window.history.pushState类似,不同之处在于replaceState不会在window.history里新增历史记录点,其效果类似于window.location.replace(url),都是不会在历史记录点里新增一个记录点的。当你为了响应用户的某些操作,而要更新当前历史记录条目的状态对象或URL时,使用replaceState()方法会特别合适。

3、监听历史记录点

监听历史记录点,直观的可认为是监听URL的变化,但会忽略URL的hash部分,监听URL的hash部分,HTML5有新的API为onhashchange,我的博客里也有说到该方法和跨浏览器的兼容解决方案。可以通过window.onpopstate来监听url的变化,并且可以获取存储在该历史记录点的状态对象,也就是上文说到的json对象,如:

// 当前的url为:http://qianduanblog.com/post-1.html
window.onpopstate=function()
{
    // 获得存储在该历史记录点的json对象
    var json=window.history.state;
    // 点击一次回退到:http://qianduanblog.com/index.html
    // 获得的json为null
    // 再点击一次前进到:http://qianduanblog.com/post-1.html
    // 获得json为{time:1369647895656}
}

值得注意的是:javascript脚本执行window.history.pushState和window.history.replaceState不会触发onpopstate事件。

还有一点注意的是,谷歌浏览器和火狐浏览器在页面第一次打开的反应是不同的,谷歌浏览器奇怪的是回触发onpopstate事件,而火狐浏览器则不会。

以上所述是小编给大家介绍的详解HTML5之pushstate、popstate操作history,无刷新改变当前url,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

HTML / CSS 相关文章推荐
使用css3做0.5px的细线的示例代码
Jan 18 HTML / CSS
CSS3关于z-index不生效问题的解决
Feb 19 HTML / CSS
html5+css3之制作header实例与更新
Dec 21 HTML / CSS
在HTML5 canvas里用卷积核进行图像处理的方法
May 02 HTML / CSS
HTML5中的进度条progress元素简介及兼容性处理
Jun 02 HTML / CSS
使用HTML5做的导航条详细步骤
Oct 19 HTML / CSS
关于webview适配H5上传照片或者视频文件的方法
Nov 04 HTML / CSS
使用canvas实现雪花飘动效果的示例代码
Mar 30 HTML / CSS
详解CSS中的特指度和层叠问题
Jul 15 HTML / CSS
CSS3中Animation实现简单的手指点击动画的示例
Jul 15 HTML / CSS
html中两种获取标签内的值的方法
Jun 10 HTML / CSS
box-shadow单边阴影的实现
May 21 HTML / CSS
HTML5无刷新改变当前url的代码
Mar 15 #HTML / CSS
HTML5各种头部meta标签的功能(推荐)
Mar 13 #HTML / CSS
处理HTML5新标签的浏览器兼容版问题
Mar 13 #HTML / CSS
HTML5 LocalStorage 本地存储刷新值还在
Mar 10 #HTML / CSS
HTML5微信播放全屏问题的解决方法
Mar 09 #HTML / CSS
通过HTML5规范搞定i、em、b、strong元素的区别
Mar 04 #HTML / CSS
HTML5 localStorage使用总结
Feb 22 #HTML / CSS
You might like
php入门学习知识点一 PHP与MYSql连接与查询
2011/07/14 PHP
php setcookie(name, value, expires, path, domain, secure) 参数详解
2013/06/28 PHP
PHP中header函数的用法及其注意事项详解
2016/06/13 PHP
PHP获取文件扩展名的常用方法小结【五种方式】
2018/04/27 PHP
有一段有意思的代码-javascript现实多行信息
2007/08/26 Javascript
jquery 防止表单重复提交代码
2010/01/21 Javascript
Jquery下的26个实用小技巧(jQuery tips, tricks & solutions)
2010/03/01 Javascript
IE6 fixed的完美解决方案
2011/03/31 Javascript
jquery 实现表单验证功能代码(简洁)
2012/07/03 Javascript
js中单引号与双引号冲突问题解决方法
2013/10/04 Javascript
JavaScript中匿名函数用法实例
2015/03/23 Javascript
javascript实现base64 md5 sha1 密码加密
2015/09/09 Javascript
根据user-agent判断蜘蛛代码黑帽跳转代码(js版与php版本)
2015/09/14 Javascript
AngularJS基础 ng-if 指令用法
2016/08/01 Javascript
jQuery实现自动输入email、时间和域名的方法
2016/08/24 Javascript
js Canvas实现圆形时钟教程
2016/09/19 Javascript
bootstrap fileinput 插件使用项目总结(经验)
2017/02/22 Javascript
详解AngularJs路由之Ui-router-resolve(预加载)
2017/06/13 Javascript
React-Router如何进行页面权限管理的方法
2017/12/06 Javascript
express如何使用session与cookie的方法
2018/01/30 Javascript
Angular父子组件通过服务传参的示例方法
2018/10/31 Javascript
微信小程序传值以及获取值方法的详解
2019/04/29 Javascript
微信小程序按钮点击动画效果的实现
2019/09/04 Javascript
微信小程序跳转到其他网页(外部链接)的实现方法
2019/09/20 Javascript
JS如何寻找数组中心索引过程解析
2020/06/01 Javascript
Python连接Redis的基本配置方法
2018/09/13 Python
Laravel+Dingo/Api 自定义响应的实现
2019/02/17 Python
pyqt5实现按钮添加背景图片以及背景图片的切换方法
2019/06/13 Python
python开启debug模式的方法
2019/06/27 Python
python的pytest框架之命令行参数详解(上)
2019/06/27 Python
python如何使用Redis构建分布式锁
2020/01/16 Python
通过python调用adb命令对App进行性能测试方式
2020/04/23 Python
详解python logging日志传输
2020/07/01 Python
英国在线电子和小工具商店:TecoBuy
2018/10/06 全球购物
旅行社各个岗位职责
2014/03/15 职场文书
《自然之道》读后感3篇
2019/12/17 职场文书