详解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 中实现炫酷的loading效果
Apr 26 HTML / CSS
CSS3中的Media Queries学习笔记
May 23 HTML / CSS
巧用 CSS3的webkit-box-reflect 倒影实现各类动效
Mar 05 HTML / CSS
HTML5触摸事件演化tap事件介绍
Mar 25 HTML / CSS
HTML5 HTMLCollection和NodeList的区别详解
Apr 29 HTML / CSS
AmazeUi Tree(树形结构) 应用小结
Aug 17 HTML / CSS
详解如何在登录过期后跳出Ifram框架
Sep 10 HTML / CSS
html table呈现个人简历以及单元格宽度失效的问题解决
Jan 22 HTML / CSS
html+css合并表格边框的示例代码
Mar 31 HTML / CSS
纯CSS实现酷炫的霓虹灯效果
Apr 13 HTML / CSS
css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效
Apr 29 HTML / CSS
HTML基础详解(上)
Oct 16 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
Extended CHM PHP 语法手册之 DIY
2006/10/09 PHP
php 获取客户端的真实ip
2009/11/30 PHP
解析php5配置使用pdo
2013/07/03 PHP
php常用字符串查找函数strstr()与strpos()实例分析
2019/06/21 PHP
Laravel如何同时连接多个数据库详解
2019/08/13 PHP
php实现多站点共用session实现单点登录的方法详解
2019/09/18 PHP
Javascript 判断 object 的特定类转载
2007/02/01 Javascript
Javascript 通过json自动生成Dom的代码
2010/04/01 Javascript
js操作时间(年-月-日 时-分-秒 星期几)
2010/06/20 Javascript
Javascript在IE和FireFox中的不同表现简析
2012/12/03 Javascript
js前台分页显示后端JAVA数据响应
2013/03/18 Javascript
JS的千分位算法实现思路
2013/07/31 Javascript
canvas压缩图片转换成base64格式输出文件流
2017/03/09 Javascript
javascript数组拍平方法总结
2018/01/20 Javascript
JS文件中加载jquery.js的实例代码
2018/05/05 jQuery
nodejs中函数的调用实例详解
2018/10/31 NodeJs
[01:04:01]2014 DOTA2国际邀请赛中国区预选赛 5 23 CIS VS DT第一场
2014/05/24 DOTA
[34:08]2018DOTA2亚洲邀请赛3月29日 小组赛B组 VP VS EG
2018/03/30 DOTA
[48:47]VGJ.S vs NB 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
python多线程threading.Lock锁用法实例
2014/11/01 Python
Python出现segfault错误解决方法
2016/04/16 Python
对Python3中的print函数以及与python2的对比分析
2018/05/02 Python
Django如何自定义model创建数据库索引的顺序
2019/06/20 Python
Win10系统下安装labelme及json文件批量转化方法
2019/07/30 Python
详解使用PyInstaller将Pygame库编写的小游戏程序打包为exe文件
2019/08/23 Python
Python3之外部文件调用Django程序操作model等文件实现方式
2020/04/07 Python
django queryset 去重 .distinct()说明
2020/05/19 Python
门卫班长岗位职责
2013/12/15 职场文书
求职信模板标准格式范文
2014/02/23 职场文书
函授生自我鉴定
2014/03/25 职场文书
幼儿园家长评语大全
2014/04/16 职场文书
入党积极分子批评与自我批评思想汇报
2014/09/14 职场文书
Idea连接MySQL数据库出现中文乱码的问题
2021/04/14 MySQL
Vue elementUI表单嵌套表格并对每行进行校验详解
2022/02/18 Vue.js
Golang 1.18 多模块Multi-Module工作区模式的新特性
2022/04/11 Golang
分析SQL窗口函数之取值窗口函数
2022/04/21 Oracle