详解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制作翻转效果_动力节点Java学院整理
Jul 11 HTML / CSS
CSS3 倾斜的网页图片库实例教程
Nov 14 HTML / CSS
css3打造一款漂亮的卡哇伊按钮
Mar 20 HTML / CSS
纯css3实现鼠标经过图片显示描述的动画效果
Sep 01 HTML / CSS
利用CSS3实现圆角的outline效果的教程
Jun 05 HTML / CSS
html5 学习简单的拾色器
Sep 03 HTML / CSS
谷歌浏览器小字体处理方案即12px以下字体
Dec 17 HTML / CSS
HTML5不支持frameset的两种解决方法
Nov 14 HTML / CSS
Html5页面内使用JSON动画的实现
Jan 29 HTML / CSS
跨域修改iframe页面内容详解
Oct 31 HTML / CSS
使用CSS实现音波加载效果
May 07 HTML / CSS
HTML 里 img 元素的 src 和 srcset 属性的区别详解
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+java实现自动新闻滚动窗口
2006/10/09 PHP
php加速器eAccelerator的配置参数、API详解
2014/05/05 PHP
php短网址和数字之间相互转换的方法
2015/03/13 PHP
php通过array_merge()函数合并两个数组的方法
2015/03/18 PHP
PHP实现的数组和XML文件相互转换功能示例
2018/03/15 PHP
javascript显示选择目录对话框的代码
2008/11/10 Javascript
一个基于jquery的图片切换效果
2010/07/06 Javascript
工作需要写的一个js拖拽组件
2011/07/28 Javascript
Javascript 类、命名空间、代码组织代码
2011/07/31 Javascript
关于cookie的初识和运用(js和jq)
2016/04/07 Javascript
JS实现为动态创建的元素添加事件操作示例
2018/03/17 Javascript
Vue cli3 库模式搭建组件库并发布到 npm的流程
2018/10/12 Javascript
使用Three.js实现太阳系八大行星的自转公转示例代码
2019/04/09 Javascript
微信小程序template模板与component组件的区别和使用详解
2019/05/22 Javascript
了解重排与重绘
2019/05/29 Javascript
vue 更改连接后台的api示例
2019/11/11 Javascript
[01:02:48]2018DOTA2亚洲邀请赛小组赛 A组加赛 Newbee vs Liquid
2018/04/03 DOTA
[40:31]Secret vs Alliacne 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
python的绘图工具matplotlib使用实例
2014/07/03 Python
Python抓取百度查询结果的方法
2015/07/08 Python
Django日志模块logging的配置详解
2017/02/14 Python
详解Django 中是否使用时区的区别
2018/06/14 Python
使用Python获取并处理IP的类型及格式方法
2018/11/01 Python
python pygame实现2048游戏
2018/11/20 Python
解决Python中定时任务线程无法自动退出的问题
2019/02/18 Python
稀有和绝版书籍:Biblio.com
2017/02/02 全球购物
墨尔本照明批发商店:Mica Lighting
2017/12/28 全球购物
Holland & Barrett爱尔兰:英国领先的健康零售商
2019/03/31 全球购物
亚马逊海外购:亚马逊美国、英国、日本、德国直邮
2021/03/18 全球购物
中间件分为哪几类
2012/03/14 面试题
小学生自我鉴定
2013/10/12 职场文书
给同学的道歉信
2014/01/16 职场文书
大学生实习证明范文(5篇)
2014/09/18 职场文书
先进教师个人主要事迹材料
2015/11/03 职场文书
《雷雨》教学反思
2016/02/20 职场文书
您对思维方式了解多少?
2019/12/09 职场文书