详解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 相关文章推荐
CSS实现聊天气泡效果
Apr 26 HTML / CSS
HTML5 Canvas API中drawImage()方法的使用实例
Mar 25 HTML / CSS
鲜为人知的HTML5语音合成功能
May 17 HTML / CSS
HTML5 语义化结构化规范化
Oct 17 HTML / CSS
使用html5+css3来实现slider切换效果告别javascript+css
Jan 08 HTML / CSS
突袭HTML5之Javascript API扩展5—其他扩展(应用缓存/服务端消息/桌面通知)
Jan 31 HTML / CSS
HTML5中的进度条progress元素简介及兼容性处理
Jun 02 HTML / CSS
详解html5 shiv.js和respond.min.js
Jan 24 HTML / CSS
HTML5自定义mp3播放器源码
Jan 06 HTML / CSS
html table呈现个人简历以及单元格宽度失效的问题解决
Jan 22 HTML / CSS
CSS3 实现的图片悬停的切换按钮
Apr 13 HTML / CSS
html2 canvas svg不能识别的解决方案
Jun 03 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 字符串压缩方法比较示例
2014/01/23 PHP
laravel 4安装及入门图文教程
2014/10/29 PHP
详解php伪造Referer请求反盗链资源
2019/01/24 PHP
符合标准的js表单提交的代码
2007/09/13 Javascript
childNodes.length与children.length的区别
2009/05/14 Javascript
jQuery 打造动态渐变按钮 详细图文教程
2010/04/25 Javascript
关于Javascript模块化和命名空间管理的问题说明
2010/12/06 Javascript
Jquery ajax传递复杂参数给WebService的实现代码
2011/08/08 Javascript
jquery Mobile入门—外部链接切换示例代码
2013/01/08 Javascript
有关javascript的性能优化 (repaint和reflow)
2013/04/12 Javascript
jquery入门必备的基本认识及实例(整理)
2013/06/24 Javascript
输入自动提示搜索提示功能的javascript:sugggestion.js
2013/09/02 Javascript
简介JavaScript中的setHours()方法的使用
2015/06/11 Javascript
js实现倒计时效果(小于10补零)
2017/03/08 Javascript
vue-cli创建的项目,配置多页面的实现方法
2018/03/15 Javascript
webpack4.0打包优化策略整理小结
2018/03/30 Javascript
微信小程序缓存支持二次开发封装实现解析
2019/12/16 Javascript
[02:44]DOTA2英雄基础教程 克林克兹
2014/01/15 DOTA
[01:02:02]DOTA2上海特级锦标赛A组败者赛 EHOME VS CDEC第二局
2016/02/25 DOTA
跟老齐学Python之永远强大的函数
2014/09/14 Python
用Python代码来解图片迷宫的方法整理
2015/04/02 Python
基于wxpython开发的简单gui计算器实例
2015/05/30 Python
python3音乐播放器简单实现代码
2020/04/20 Python
浅析Python 读取图像文件的性能对比
2019/03/07 Python
pandas计算最大连续间隔的方法
2019/07/04 Python
对Django中内置的User模型实例详解
2019/08/16 Python
Python通过format函数格式化显示值
2020/10/17 Python
意大利专业化妆品品牌:KIKO MILANO
2017/02/01 全球购物
美国第二大连锁药店:Rite Aid
2019/04/03 全球购物
教师考核表个人总结
2015/02/12 职场文书
企业财务经理岗位职责
2015/04/08 职场文书
2015中秋节晚会开场白
2015/07/30 职场文书
Python天气语音播报小助手
2021/09/25 Python
python调用ffmpeg命令行工具便捷操作视频示例实现过程
2021/11/01 Python
SpringBoot+Redis实现布隆过滤器的示例代码
2022/03/17 Java/Android
VUE递归树形实现多级列表
2022/07/15 Vue.js