前面的话

  history对象保存着用户上网的历史记录,从窗口被打开的那一刻算起。由于安全方面的考虑,开发人员无法得到用户浏览器的URL,但借由用户访问过的页面列表,可以在不知道实际URL的情况下实现后退和前进。本文将详细介绍BOM中的history对象

length

  history.length属性保存着历史记录的URL数量。初始时,该值为1。如果当前窗口先后访问了三个网址,history.length属性等于3

  由于IE10+浏览器在初始时返回2,存在兼容性问题,所以该值并不常用

history.length // 初始时,该值为1
history.length // 访问三个网址后,该值为3

跳转方法

  history对象提供了一系列方法,允许在浏览历史之间移动,包括go()、back()和forward()

【go()】

  使用go()方法可以在用户的历史记录中任意跳转。这个方法接收一个参数,表示向后或向前跳转的页面数的一个整数值。负数表示向后跳转(类似于后退按钮),正数表示向前跳转(类似于前进按钮)

//后退一页
history.go(-1)
//前进一页
history.go(1);
//前进两页
history.go(2);

  go()方法无参数时,相当于history.go(0),可以刷新当前页面

//刷新当前页面
history.go();
//刷新当前页面
history.go(0);

【back()】

  back()方法用于模仿浏览器的后退按钮,相当于history.go(-1)

【forward()】

  forward()方法用于模仿浏览器的前进按钮,相当于history.go(1)

//后退一页
history.back()
//前进一页
history.forward()

  如果移动的位置超出了访问历史的边界,以上三个方法并不报错,而是静默失败

  [注意]使用历史记录时,页面通常从浏览器缓存之中加载,而不是重新要求服务器发送新的网页

增改记录

  HTML5为history对象添加了两个新方法,history.pushState()和history.replaceState(),用来在浏览历史中添加和修改记录。state属性用来保存记录对象,而popstate事件用来监听history对象的变化

  [注意]IE9-浏览器不支持

【pushState()】

  history.pushState()方法向浏览器历史添加了一个状态。pushState()方法带有三个参数:一个状态对象、一个标题(现在被忽略了)以及一个可选的URL地址

history.pushState(state, title, url);

state object —— 状态对象是一个由pushState()方法创建的、与历史纪录相关的javascript对象。当用户定向到一个新的状态时,会触发popstate事件。事件的state属性包含了历史纪录的state对象。如果不需要这个对象,此处可以填null
title —— 新页面的标题,但是所有浏览器目前都忽略这个值,因此这里可以填null
URL —— 这个参数提供了新历史纪录的地址。新URL必须和当前URL在同一个域,否则,pushState()将丢出异常。这个参数可选,如果它没有被特别标注,会被设置为文档的当前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是否存在,它只是成为浏览历史中的最新记录。假如这时访问了google.com,然后点击了倒退按钮,页面的url将显示2.html,但是内容还是原来的1.html。再点击一次倒退按钮,url将显示1.html,内容不变

  总之,pushState方法不会触发页面刷新,只是导致history对象发生变化,地址栏的显示地址发生变化

  如果pushState的url参数,设置了一个新的锚点值(即hash),并不会触发hashchange事件,即使新的URL和旧的只在hash上有区别

  如果设置了一个跨域网址,则会报错。这样设计的目的是,防止恶意代码让用户以为他们是在另一个网站上

// 报错
history.pushState(null, null, 'https://twitter.com/hello');

【replaceState()】

  history.replaceState方法的参数与pushState方法一模一样,不同之处在于replaceState()方法会修改当前历史记录条目而并非创建新的条目

  假定当前网页是example.com/example.html

history.pushState({page: 1}, 'title 1', '?page=1');
history.pushState({page: 2}, 'title 2', '?page=2');
history.replaceState({page: 3}, 'title 3', '?page=3');history.back()
// url显示为http://example.com/example.html?page=1history.back()
// url显示为http://example.com/example.htmlhistory.go(2)
// url显示为http://example.com/example.html?page=3

【state】

  history.state属性返回当前页面的state对象

history.pushState({page: 1}, 'title 1', '?page=1');history.state// { page: 1 }

【popstate事件】

  每当同一个文档的浏览历史(即history对象)出现变化时,就会触发popstate事件

  需要注意的是,仅仅调用pushState方法或replaceState方法,并不会触发该事件,只有用户点击浏览器倒退按钮和前进按钮,或者使用javascript调用back()、forward()、go()方法时才会触发。另外,该事件只针对同一个文档,如果浏览历史的切换,导致加载不同的文档,该事件也不会触发

  使用的时候,可以为popstate事件指定回调函数。这个回调函数的参数是一个event事件对象,它的state属性指向pushState和replaceState方法为当前URL所提供的状态对象(即这两个方法的第一个参数)

window.onpopstate = function (event) {console.log('location: ' + document.location);console.log('state: ' + JSON.stringify(event.state));
};

  上面代码中的event.state,就是通过pushState和replaceState方法,为当前URL绑定的state对象

  这个state对象也可以直接通过history对象读取

var currentState = history.state;

往返缓存

  默认情况下,浏览器会在当前会话(session)缓存页面,当用户点击“前进”或“后退”按钮时,浏览器就会从缓存中加载页面

  浏览器有一个特性叫“往返缓存”(back-forward cache或bfcache),可以在用户使用浏览器的“后退”和“前进”按钮时加快页面的转换速度。这个缓存中不仅保存着页面数据,还保存了DOM和javascript的状态;实际上是将整个页面都保存在了内存里。如果页面位于bfcache中,那么再次打开该页面时就不会触发load事件

  [注意]IE10-浏览器不支持

【pageshow】

  pageshow事件在页面加载时触发,包括第一次加载和从缓存加载两种情况。如果要指定页面每次加载(不管是不是从浏览器缓存)时都运行的代码,可以放在这个事件的监听函数

  第一次加载时,它的触发顺序排在load事件后面。从缓存加载时,load事件不会触发,因为网页在缓存中的样子通常是load事件的监听函数运行后的样子,所以不必重复执行。同理,如果是从缓存中加载页面,网页内初始化的JavaScript脚本(比如DOMContentLoaded事件的监听函数)也不会执行

  [注意]虽然这个事件的目标是document,但必须将其事件处理程序添加到window

  pageshow事件有一个persisted属性,返回一个布尔值。页面第一次加载时或没有从缓存加载时,这个属性是false;当页面从缓存加载时,这个属性是true

(function(){var showCount = 0;window.onload = function(){console.log('loaded');}window.onpageshow = function(e){e = e || event;showCount ++;console.log(e.persisted,showCount + 'times');}
})();

  [注意]上面的例子使用了私有作用域,以防止变量showCount进入全局作用域。如果单击了浏览器的“刷新”按钮,那么showCount的值就会被重置为0,因为页面已经完全重新加载了

【pagehide】

  与pageshow事件对应的是pagehide事件,该事件会在浏览器卸载页面的时候触发,而且是在unload事件之前触发。与pageshow事件一样,pagehide在document上面触发,但其事件处理程序必须要添加到window对象

  [注意]指定了onunload事件处理程序的页面会被自动排除在bfcache之外,即使事件处理程序是空的。原因在于,onunload最常用于撤销在onload中所执行的操作,而跳过onload后再次显示页面很可能就会导致页面不正常

  pagehide事件的event对象也包含persisted属性,不过其用途稍有不同。如果页面是从bfcache中加载的,那么persisted的值就是true;如果页面在卸载之后会被保存在bfcache中,那么persisted的值也会被设置为true。因此,当第一次触发pageshow时,persisted的值一定是false,而在第一次触发pagehide时,persisted就会变成true(除非页面不会被保存在bfcache中)

window.onpagehide = function(e){e = e || event;console.log(e.persisted);
}

转载于:https://www.cnblogs.com/lcspring/p/10839100.html

BOM函数之history对象相关推荐

  1. BOM中的history对象和navigator对象

    history对象 前进功能 history.forward() 或者history.go(n) 后退功能 history.back() 或者history.go(-n) 一般情况下不需要这个功能,O ...

  2. javascript的浏览器Bom详解,window、location、history对象

           BOM(BrowserObjectModel)也叫浏览器对象模型,描述与浏览器进行交互的方法和接口.BOM由多个对象组成, 其中代表浏览器窗口的Window对象是BOM的顶层对象,其他对 ...

  3. BOM--location对象、history对象

    location对象 location 是最有用的BOM 对象之一,它提供了与当前窗口中加载的文档有关的信息,还提供了一些导航功能. 事实上,location 对象是很特别的一个对象,因为它既是win ...

  4. JavaScript基础15-day17【BOM(Navigator、History、Location)、定时器、切换图片练习、轮播图】

    学习地址: 谷粒学院--尚硅谷 哔哩哔哩网站--尚硅谷最新版JavaScript基础全套教程完整版(140集实战教学,JS从入门到精通) JavaScript基础.高级学习笔记汇总表[尚硅谷最新版Ja ...

  5. JavaScript History对象

    2019独角兽企业重金招聘Python工程师标准>>> window.history 对象包含浏览器的历史. 浏览者通常可以使用浏览器的前进与后退按钮访问曾经浏览过的页面.JavaS ...

  6. 用Location对象和history对象修改页面url

    用Location对象和history对象修改页面url 1.通过hash属性更改url Location 对象包含有关当前 URL 的信息 Location.hash是URL的锚部分 Locatio ...

  7. 深入学习 History 对象管理浏览器会话历史

    History对象允许我们操作浏览器会话历史,即加载当前页面的标签页窗口或frame窗口的访问历史.之前有同学咨询我如何实现拦截用户跳转页面并强制用户返回首页后重新请求页面,于是有了本篇博客的主题,本 ...

  8. python中history()_keras中的History对象用法

    keras中的fit_generator和fit函数均返回History对象,那么History怎么用呢?事实上History对象已经记录了运行输出.在了解之前,我们甚至自己定义回调函数记录损失和准确 ...

  9. JavaScript 基础(三) - Date对象,RegExp对象,Math对象,Window 对象,History 对象,Location 对象,DOM 节点...

    Date对象 创建Date对象 //方法1:不指定参数var date_obj = new Date();alert(date_obj.toLocaleString())//方法2:参数为日期字符串v ...

最新文章

  1. Docker(三):镜像导入与导出、保存与加载、在Docker容器中安装软件
  2. USB连接TF卡 SD卡硬件电路
  3. mysql atlas php_Mysql中间件代理 Atlas
  4. centos下 Tcpreplay 重放数据(流量采集重放)
  5. 用MDT 2012为企业部署windows 7(七)--创建标准操作系统部署任务序列
  6. 设计灵感|延展画面的插画Banner设计!
  7. Linux多线程与Linux多进程混合项目的死锁问题
  8. Go -- 调用C/C++
  9. arduino 嗡鸣器 音乐_arduino蜂鸣器怎么输出指定的音乐
  10. linux在shell中获取时间 date巧用
  11. 一张图片分成两张matlab,matlab – 两幅图像之间的相似度量
  12. 小米手机图标应用图标不改变的问题
  13. win7系统定时删除数据的批处理命令_简单的批量清除垃圾bat命令
  14. 分治回溯--Nqueen
  15. python读取一个文件夹下所有图片_初学Python-找出文件夹下的所有图片
  16. Windows XP 启动过程jjhou
  17. php dth网络节点,基于 DHT 网络的磁力链接和BT种子的搜索引擎架构
  18. 时间t与时间管理——柳比歇夫、德鲁…
  19. 记录建hbase对应hive外表坑
  20. 生物信息学数据库资源 {#database}

热门文章

  1. 共享按摩椅理财系统|金融投资理财系统
  2. Java | 用Java实现选择排序算法(记录写程序全过程的编程哲学)
  3. java 委托原则_为什么说 Java SPI 的设计违反双亲委派原则
  4. chromedriver@2.41.0 install: `node install.js`安装失败解决;npm安装报错
  5. 粽子SHOP-粽子商城官网-一款简洁大气的官网源码
  6. OllyDBG 入门系列(三)-函数
  7. 远程连接“终端服务器超出了最大允许连接数” 解决
  8. mysql —— 分表分区
  9. CSS:去除点击链接和按钮时出现的虚线框
  10. Swift中文教程(十四) 初始化