详解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 24 HTML / CSS
实现CSS3中的border-radius(边框圆角)示例代码
Jul 19 HTML / CSS
CSS3中几个新增加的盒模型属性使用教程
Mar 01 HTML / CSS
详解CSS3中的box-sizing(content-box与border-box)
Apr 19 HTML / CSS
css3通过scale()、rotate()实现放大、旋转
Mar 19 HTML / CSS
html5中localStorage本地存储的简单使用
Jun 16 HTML / CSS
使用html5+css3来实现slider切换效果告别javascript+css
Jan 08 HTML / CSS
基于第一个PhoneGap(cordova)的应用详解
May 03 HTML / CSS
深入浅析HTML5中的article和section的区别
May 15 HTML / CSS
跨域修改iframe页面内容详解
Oct 31 HTML / CSS
AmazeUI 等分网格的实现示例
Aug 25 HTML / CSS
HTML5简单实现添加背景音乐的几种方法
May 12 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学习之php4与php5之间会穿梭一点点感悟
2007/05/03 PHP
php微信开发之上传临时素材
2016/06/24 PHP
PHP序列化操作方法分析
2016/09/28 PHP
禁止js文件缓存的代码
2010/04/09 Javascript
asp.net网站开发中用jquery实现滚动浏览器滚动条加载数据(类似于腾讯微博)
2012/03/14 Javascript
js获取元素到文档区域document的(横向、纵向)坐标的两种方法
2013/05/17 Javascript
JavaScript版TAB选项卡效果实例
2013/08/16 Javascript
js通过location.search来获取页面传来的参数
2014/09/11 Javascript
同一个网页中实现多个JavaScript特效的方法
2015/02/02 Javascript
关于JavaScript数组你所不知道的3件事
2016/08/24 Javascript
JS基于递归实现倒计时效果的方法
2016/11/26 Javascript
纯jQuery实现前端分页功能
2017/03/23 jQuery
利用纯js + transition动画实现移动端web轮播图详解
2017/09/10 Javascript
vue.js简单配置axios的方法详解
2017/12/13 Javascript
Vue项目全局配置微信分享思路详解
2018/05/04 Javascript
JS实现点击拉拽轮播图pc端移动端适配
2018/09/05 Javascript
解决vuejs 使用value in list 循环遍历数组出现警告的问题
2018/09/26 Javascript
JavaScript获取时区实现过程解析
2020/09/24 Javascript
Python 开发Activex组件方法
2009/11/08 Python
python 多进程通信模块的简单实现
2014/02/20 Python
python实现探测socket和web服务示例
2014/03/28 Python
tensorflow入门之训练简单的神经网络方法
2018/02/26 Python
django 发送邮件和缓存的实现代码
2018/07/18 Python
python3.6实现学生信息管理系统
2019/02/21 Python
python常用库之NumPy和sklearn入门
2019/07/11 Python
django 框架实现的用户注册、登录、退出功能示例
2019/11/28 Python
html5定位获取当前位置并在百度地图上显示
2014/08/22 HTML / CSS
简述你对Statement,PreparedStatement,CallableStatement的理解
2013/03/25 面试题
销售找工作求职信
2013/12/20 职场文书
节水倡议书
2015/01/19 职场文书
2015年社区文体活动总结
2015/03/25 职场文书
边城读书笔记
2015/06/29 职场文书
如何使用JavaScript策略模式校验表单
2021/04/29 Javascript
Ajax异步刷新功能及简单案例
2021/11/20 Javascript
Python Django / Flask如何使用Elasticsearch
2022/04/19 Python
Python探索生命起源 matplotlib细胞自动机动画演示
2022/04/21 Python