详解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实现多个元素依次显示效果
Dec 12 HTML / CSS
HTML5 Plus 实现手机APP拍照或相册选择图片上传功能
Jul 13 HTML / CSS
html5 touch事件实现触屏页面上下滑动(一)
Mar 10 HTML / CSS
HTML5之SVG 2D入门13—svg对决canvas及长处和适用场景分析
Jan 30 HTML / CSS
HTML5的hidden属性兼容老浏览器的方法
Apr 23 HTML / CSS
利用HTML5 Canvas制作一个简单的打飞机游戏
May 11 HTML / CSS
Html5实现用户注册自动校验功能实例代码
May 24 HTML / CSS
浅谈html5 video 移动端填坑记
Jan 15 HTML / CSS
canvas线条的属性详解
Mar 27 HTML / CSS
关于canvas绘制模糊问题的解决方法
Sep 24 HTML / CSS
Canvas如何做个雪花屏版404的实现
Sep 25 HTML / CSS
使用HBuilder制作一个简单的HTML5网页
Jul 07 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
程序员的表白神器“520”大声喊出来
2016/05/20 PHP
浅析PHP中json_encode与json_decode的区别
2020/07/15 PHP
firefox下frameset取不到值的解决方法
2010/09/06 Javascript
Jquery插件编写简明教程
2014/03/25 Javascript
node.js中的fs.utimesSync方法使用说明
2014/12/15 Javascript
jQuery解决input超多的表单提交
2015/08/10 Javascript
举例讲解JavaScript中关于对象操作的相关知识
2015/11/16 Javascript
基于Bootstrap3表格插件和分页插件实例详解
2016/05/17 Javascript
实用jquery操作表单元素的简单代码
2016/07/04 Javascript
Angularjs根据json文件动态生成路由状态的实现方法
2017/04/17 Javascript
angularJS模态框$modal实例代码
2017/05/27 Javascript
手动下载Chrome并解决puppeteer无法使用问题
2018/11/12 Javascript
jQuery实现点击旋转,再点击恢复初始状态动画效果示例
2018/12/11 jQuery
小程序实现分类页
2019/07/12 Javascript
详解webpack打包vue项目之后生成的dist文件该怎么启动运行
2019/09/06 Javascript
javascript 易错知识点实例小结
2020/04/25 Javascript
vue 实现element-ui中的加载中状态
2020/11/11 Javascript
[01:38]【DOTA2亚洲邀请赛】Sumail——梦开始的地方
2017/03/03 DOTA
python3批量删除豆瓣分组下的好友的实现代码
2016/06/07 Python
Python实现解析Bit Torrent种子文件内容的方法
2017/08/29 Python
python+unittest+requests实现接口自动化的方法
2018/11/29 Python
python文件读写代码实例
2019/10/21 Python
Python matplotlib以日期为x轴作图代码实例
2019/11/22 Python
使用python实现希尔、计数、基数基础排序的代码
2019/12/25 Python
Python3 全自动更新已安装的模块实现
2020/01/06 Python
python 实现汉诺塔游戏
2020/11/28 Python
HTML5实现签到 功能
2018/10/09 HTML / CSS
ASOS比利时:英国线上零售商及自有品牌
2018/07/29 全球购物
Laravel的加密解密与哈希实例讲解
2021/03/24 PHP
教师开学感言
2014/02/14 职场文书
英文自荐信常用句子
2014/03/26 职场文书
单位委托书怎么写
2014/08/02 职场文书
客服专员岗位职责
2015/02/10 职场文书
格林童话读书笔记
2015/06/30 职场文书
创业计划书之废品回收
2019/09/26 职场文书
阿里面试Nacos配置中心交互模型是push还是pull原理解析
2022/07/23 Java/Android