当前窗口的浏览历史 window.history 对象

保存了当前窗口访问过的所有页面网址

由于安全原因,浏览器不允许脚本读取这些地址,但是允许在地址之间导航

history.back() 相当于 history.go(-1)

浏览器工具栏的 “前进” 和 “后退” 按钮,其实就是对 History 对象进行操作

  • // 当前窗口访问过多少个网页
    window.history.length // // History 对象的当前状态
    // 通常是 undefined,即未设置
    window.history.state // undefined

主要有两个属性

  • history.length ---- 当前窗口访问过的网址数量(包括当前网页)
  • history.state ---- history 堆栈 最上层的状态值

5 个方法

history.back() ---- 移动到上一个网址,等同于点击浏览器的后退键

对于第一个访问的网址,该方法无效果

history.forward() ---- 移动到下一个网址,等同于点击浏览器的前进键

对于最后一个访问的网址,该方法无效果

history.go() ---- 接受一个整数作为参数,以当前网址为基准,移动到参数指定的网址

比如  go(1) 相当于forward()     go(-1)相当于back()

如果参数超过实际存在的网址范围,该方法无效果

如果不指定参数,默认参数为 0,相当于刷新当前页面

注意: 移动到以前访问过的页面时,页面通常是从浏览器缓存之中加载,而不是重新要求服务器发送新的网页

history.pushState() ---- 用于在历史中添加一条记录

window.history.pushState(state, title, url)

不会触发页面刷新,只是导致 history 对象发生变化,地址栏会有反应

使用该方法之后,就可以用 history.state属性读出状态对象

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

    如果 pushState 的 URL 参数设置了一个新的锚点值(即 hash),并不会触发 hashchange 事件

  • 反过来,如果 URL 的锚点值变了,则会在 history 对象创建一条浏览记录
  • 如果pushState()方法设置了一个跨域网址,则会报错

这样设计的目的是,防止恶意代码让用户以为他们是在另一个网站上

因为这个方法不会导致页面跳转

接受三个参数

state ---- 一个与添加的记录相关联的状态对象,主要用于 popstate 事件

该事件触发时,该对象会传入回调函数

也就是说,浏览器会将这个对象序列化以后保留在本地

重新载入这个页面的时候,可以拿到这个对象。

如果不需要这个对象,此处可以填 null

title ---- 新页面的标题

现在所有浏览器都忽视这个参数,所以这里可以填空字符串

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

你再点击一次倒退按钮,URL 将显示 1.html

history.replaceState() ---- 用来修改 History 对象的当前记录,其他都与 pushState() 方法一模一样

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

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

popstate 事件

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

仅仅调用 pushState() 方法或 replaceState() 方法 ,并不会触发该事件

该事件只针对同一个文档,如果浏览历史的切换,导致加载不同的文档,该事件也不会触发

  • window.onpopstate = function (event) {
    console.log('location: ' + document.location);
    console.log('state: ' + JSON.stringify(event.state));
    }; // 或者
    window.addEventListener('popstate', function(event) {
    console.log('location: ' + document.location);
    console.log('state: ' + JSON.stringify(event.state));
    });

回调函数的参数是一个event事件对象

它的 state属性指向 pushState 和 replaceState 方法为当前 URL 所提供的状态对象(即这两个方法的第一个参数)

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

var currentState = history.state;

注意,页面第一次加载的时候,浏览器不会触发popstate事件

BOM 浏览器对象模型_当前窗口的浏览历史 history 对象的更多相关文章

  1. BOM 浏览器对象模型_不超过 4 KB 的 document.cookie 对象

    注意: 客户端储存应该使用 Web storage API 和 IndexedDB,不推荐使用 Cookie document.cookie 对象 是服务器保存在浏览器的一小段文本信息 用于读写当前网 ...

  2. BOM 浏览器对象模型_同源限制

    “同源政策”(same-origin policy) 浏览器安全的基石 协议相同 域名相同 端口相同 1995年,同源政策由 Netscape 公司引入浏览器.目前,所有浏览器都实行这个政策 A 网页 ...

  3. BOM 浏览器对象模型_渲染引擎_JavaScript 引擎_网页加载流程

    1. 浏览器核心的两个组成部分 渲染引擎 将网页代码渲染为用户视觉可以感知的平面文档 分类: Firefox        Gecko 引擎 Safari        WebKit 引擎 Chrom ...

  4. BOM浏览器对象模型

    访问和操作浏览器窗口的模型称为浏览器对象模型BOM(Browser Object Model). BOM整体对象图. 核心是window对象: 以下有特殊双重身份: window对象既是ECMAScr ...

  5. 第一百一十一节,JavaScript,BOM浏览器对象模型

    JavaScript,BOM浏览器对象模型 学习要点: 1.window对象 2.location对象 3.history对象 BOM也叫浏览器对象模型,它提供了很多对象,用于访问浏览器的功能.BOM ...

  6. javascript高级程序设计第3版——第8章 BOM(浏览器对象模型)

    第八章,浏览器对象模型 主要介绍了window的几个对象以及框架,窗口的关系,各个浏览器对象的属性以及方法:

  7. JavaScript——BOM(浏览器对象模型),时间间隔和暂停

    BOM(浏览器对象模型):能够对浏览器的窗体进行訪问和操作 1.主要的BOM体系: window------------document-------------------------------- ...

  8. js BOM浏览器对象模型

    BOM即Browser Object Model,浏览器对象模型,表示浏览器窗口,所有js全局对象.函数以及变量均是window 对象的成员. 对于不同的浏览器,表示宽度和高度的方法不同: 对于IE9 ...

  9. BOM——浏览器对象模型(Browser Object Model)

    什么是BOM? BOM是Browser Object Model的缩写,简称浏览器对象模型 BOM提供了独立于内容而与浏览器窗口进行交互的对象 由于BOM主要用于管理窗口与窗口之间的通讯,因此其核心对 ...

随机推荐

  1. va注解应用实例 - Annotation, 自定义注解, 注解类规则【转】

    本文介绍了java的自定义注解及注解类编写的规则, 并通过实例来说明下如何使用java的注解. 实例演示了注解在类,构造方法,方法和字段的使用. 可以从这里下载到完成的工程代码: http://dl. ...

  2. SpringBoot系列: CommandLineRunner接口的用处

    ========================================使用 CommandLineRunner 对Spring Bean进行额外初始化==================== ...

  3. 我是怎么知道 PTHREAD_MUTEX_INITIALIZER 是什么鬼东西的 ??

    很简单 写这么几句代码 1 #include <pthread.h> 2 3 PTHREAD_MUTEX_INITIALIZER cpp 一解析就出来了 1714 # 238 " ...

  4. 深入浅出UE4网络

    UE4中的官方文档结构比较混乱,且有部分错误,不方便学习.笔者试图通过本文,整理出一篇关于UE4网络的文章,方便朋友们对UE4中的网络同步部分的认识,并有进一步理解.如有讲得不清楚明白的地方,还望批评 ...

  5. Ubuntu 18.04 LTS搭建GO语言开发环境

    一.下载Go语言安装包 官网下载地址:https://golang.org/dl/,使用tar命令将档案包解压到/usr/local目录中: sudo tar -C /usr/local -xzf g ...

  6. 用agular2做文件上传功能杂记-遁地龙卷风

    (-1)功能描述 写一个功能,前台发起执行请求,后台执行任务,前台可以获取执行的进度,并取得最后的执行状态. (0)angular2 $http文件上传 这里之所以不用angular-file-upl ...

  7. BootStrap分页教程

    https://www.cnblogs.com/laowangc/p/8875526.html https://www.cnblogs.com/yinglunstory/p/6092834.html ...

  8. javascript基础 之 void

    1,viod是什么? javascript:void(0) 这样的代码是js中很常用的代码,void是javascript中定义的一个操作符,void后面跟一个表达式,void操作符会立即执行后面的表 ...

  9. MySQL建表规范

    一.基础规范 (1)必须使用InnoDB存储引擎 解读:支持事务.行级锁.并发性能更好.CPU及内存缓存页优化使得资源利用率更高 (2)必须使用UTF8字符集 解读:万国码,无需转码,无乱码风险,节省 ...

  10. Kafka简单使用

    前言 这几天在写 shell 脚本,学到不少,但是没啥心得之类的,有空可以写个总结(但是大概率不会发表) 现在不算很忙,想再学一点 消息队列相关知识 目前比较出名的也就 RabbitMQ 和 Kafk ...