此博客是本人从学生时代开始做笔记所用, 部分是工作所遇问题,做填坑笔记,部分闲来查阅资料,加上自己的理解所总结的学习笔记, 常忙得不可开交,若漏了资料来源,望通知~ 前路漫漫,写点东西告诉自己正在一点点进步,而不要迷失于繁忙。

history新增方法

history对象包含用户访问过的URL,属于window对象的一部分,传统的使用中,它拥有length属性(浏览器历史列表URL数目)

及back()、forward()、go()方法。

 

而新的H5则赋予了其更多的新特性:

 

往返缓存

默认情况下,浏览器会缓存当前会话页面,这样当下一个页面点击后退按钮,或前一个页面点击前进按钮,浏览器便会从缓存中提取并加载此页面,这个特性被称为“往返缓存”。

备注: 此缓存会保留页面数据、DOM和js状态,实际上是将整个页面完好无缺地保留

------------沉默分割线-----------------------------------------------------------------------------------------------------------------------

pushState(state, title, url) 

往历史记录栈中添加记录

支持度: IE10+

state: 一个js对象,主要用于在popstate事件中作为参数被获取

title: 新页面的标题,部分浏览器(比如firefox)忽略此参数,因此一般为null

url: 新历史记录的地址,可为页面地址也可为一个锚点值,新url必须与当前url处于同一个域,否则将抛出异常,此参数若没有特别标注,会被设为当前文档url

实例:

假定当前网址是example.com/1.html,使用pushState方法在浏览记录(history对象)中添加一个新记录

var stateObj = { foo: 'bar' };
history.pushState(stateObj, 'page 2', '2.html');

浏览器地址栏将立即变成example.com/2.html,但并不会跳转到2.html,甚至不会检查2.html是否存在,也不会再popstate事件中获取,因为:这个方法仅仅是添加了一条最新记录,不会触发页面刷新

备注:

1.将url设为锚点值时不会触发hashchange

2.如果设置不同域名地址,会报错,这样做的目的是:防止用户以为它们是同一个网站,若没有此限制,将很容易进行XSS、CSRF等攻击方式

------------华丽分割线--------------------------------------------------------------------------------------------------------------------------

replaceState(state, title, url)

支持度: IE10+

参数与pushState一致,但其功能是改变当前的历史记录而不是添加新的记录。

同样不会触发popstate

------------璀璨分割线--------------------------------------------------------------------------------------------------------------------------

history.state

支持度: IE10+

返回当前历史记录的state

--------------曼妙分割线---------------------------------------------------------------------------------------------------------------------

popstate事件

支持度: IE10+

语法: window.onpopstate= function(event){

  console.log(event.state) //当前历史记录的state对象

}//注意大小写

 

触发条件: 点击前进后退按钮、调用back()、forward()、go()

个人思考: 对于pushState、replaceState无法触发它,可以从语义上理解,pop有弹出、提取出的意味,是从历史记录栈中提取出来,而pushState、replaceState分别是压入栈和改变元素,自然不会触发。

 

posted @ 2017-10-09 16:51  炎泽  阅读(1985)  评论(0编辑  收藏  举报