使用 JavaScript 操作浏览器历史记录 API
History 是 window 对象中的一个 JavaScript 对象,它包含了关于浏览器会话历史的详细信息。你所访问过的 URL 列表将被像堆栈一样存储起来。浏览器上的返回和前进按钮使用的就是 history 的信息。
History 对象包含长度属性,它包含了会话历史记录栈中的 URL 数量。例如,如果用户在浏览器中打开一个标签页,历史记录的长度将是 1(新的标签页也是一个网页)。然后用户输入一个网址 foo.com 并点击回车,现在历史记录对象的长度将是 2, 用户转到其他页面 bar.com,历史记录对象的长度将就是 3 了。
Back 和 Forward 方法
你可以使用 history 对象的 back
和 forward
方法来浏览网页。例如,如果你想转到上一个页面,那么可以使用:
history.back()
同样的,如果你想转到下一页,你可以使用:
history.forward()
Go 方法
如果您想向前或向后移动 n 个页面,那么您可以使用 go 方法:
history.go(-2) // 倒退 2 页
history.go(2) // 前进 2 页
所以 history.go(1)
和 history.forward()
效果是相同的,history.go(-1)
和 history.go(-1)
效果是相同的。history.go
方法的默认值为 0,如果不传任何数字,则当前页面会被刷新。
window.history.go(0)
window.history.go()
PushState
你也可以使用 pushState
和 replaceState
方法改变页面的 URL。pushState
会改变页面的 URL,并将改变后的 URL 添加到 history
对象的 URL 栈顶部。语法如下:
history.pushState(state, title, url)
参数 state 是状态数据,它将被存储在 history.state 变量中。参数 title 是标题文本,不过它对大多数浏览器都没有效果,所以一般传空字符串("")或传 null 就可以了。
让我们在控制台中尝试一下,在执行之前,比如打开 baidu.com,然后在控制台输入:
history.pushState('123', '', 'new-url')
执行上面的代码后,它会将页面地址栏中的 URL 改为 baidu.com/new-url,同时将 URL 添加到 history 对象中。此时检查 history.length
会增加 1。
除此之外,我们还可以为每个 URL 存储状态(当前页面的数据)。在上面的例子中,你会把 "123" 存储在 history.state
变量中,当你返回到这个页面时,你就可以 history.state
再次拿到到这些数据。例如:
history.pushState('temp data 1', 'title', 'new-url-1')
history.state //"temp data 1"
history.pushState('temp data 2', 'title', 'new-url-2')
history.state //"temp data 2"
history.back()
history.state // "temp data 1"
每当通过 pushState 返回到之前被添加到历史记录的页面时,浏览器就会触发一个名为 popstate 的事件,并将 state 数据作为参数。比如在浏览器打开一个新标签页,进入某个网页(比如 baidu.com),先监听 popstate 事件:
window.addEventListener('popstate', (e) => console.log(e))
然后调用 pushState:
history.pushState({ name: 'test1' }, 'title', 'test1')
然后按下返回按钮,popstate 事件就会被触发,你可以在监听事件中查看打印出来的数据。在打印的数据中,可以找到 history.state 的值。
注册 pushState 中的 url 可以是完整的 url,但必须和当前页面是相同的域名,否则会抛出跨域异常。
浏览器还有一个 replaceState
API,和 pushState
的区别是,它只改变了 URL,不会将 URL 添加到历史记录,这里就不再累述了。
实例演示
现在我们做一个小的网页应用,这个应用将实现如下功能:
- 显示用户列表
- 可以通过下拉框筛选“先生”和“女士”
- 当下列列表发生变化时,URL 也会相应的变化
我们先不关心 history API,先实现功能。下面是 html 关键代码:
<select id="selectbox">
<option value="both">全部</option>
<option value="male">先生</option>
<option value="femalt">女士</option>
</select>
<ul id="userslist">
<li gender="male">张先生</li>
<li gender="female">李女士</li>
<li gender="female">王女士</li>
</ul>
下面是 javascript 关键代码:
let selectBox = document.getElementById('selectBox')
let usersList = document.getElementById('usersList')
selectBox.addEventListener('change', onSelectBoxChange)
function onSelectBoxChange(ev) {
let val = this.value
filterList(val)
}
function filterList(val) {
let users = usersList.children
for (let i = 0; i < users.length; i++) {
let user = users[i]
let gender = user.getAttribute('gender')
if (gender === val || val === 'both') {
user.style.display = ''
} else {
user.style.display = 'none'
}
}
}
实现后的效果如下:
当修改下拉列表时,为了使浏览器地址也发生变化,需要使用 pushSate
方法:
function onSelectBoxChange(ev) {
let val = this.value
filterList(val)
history.pushState({ gender: val }, null, val)
}
当我们在下拉框选择“先生”时,浏览器的地址会变成:localhost:5000/male。效果如下:
此时会有个问题,当我们点击前进/后退时,浏览器地址变了,但对应的数据却不对。因此,当进行前进/后退时,我们需要监听 popstate 重新过滤数据:
window.addEventListener('popstate', onPopState)
function onPopState(ev) {
let state = ev.state
filterList(state.gender)
}
我们还需要处理页面刷新的问题。当刷新页面时,历史记录不会改变,history.state
的状态值也保持不变。所以我们可以从 history.state
中取出当前的状态数据,利用 state.gender
的值就可以在 load
事件中来过虑出当前 URL 对应的用户列表:
window.addEventListener('load', function () {
let gender = history.state ? history.state.gender : 'both'
filterList(gender)
})
这是个简单的示例,你也可以继续进一步优化。今天的分享就到这里,有问题请在下面留言哦~~
使用 JavaScript 操作浏览器历史记录 API的更多相关文章
- 【repost】Javascript操作DOM常用API总结
Javascript操作DOM常用API总结 文本整理了javascript操作DOM的一些常用的api,根据其作用整理成为创建,修改,查询等多种类型的api,主要用于复习基础知识,加深对原生js的认 ...
- JavaScript 操作 DOM 常用 API 总结
文本整理了javascript操作DOM的一些常用的api,根据其作用整理成为创建,修改,查询等多种类型的api,主要用于复习基础知识,加深对原生js的认识. 基本概念 在讲解操作DOM的api之前, ...
- Javascript操作DOM常用API总结
基本概念 在讲解操作DOM的api之前,首先我们来复习一下一些基本概念,这些概念是掌握api的关键,必须理解它们. Node类型 DOM1级定义了一个Node接口,该接口由DOM中所有节点类型实现.这 ...
- 理解浏览器历史记录(2)-hashchange、pushState
本文也是一篇基础文章.继上文之后,本打算去研究pushState,偶然在一些信息中发现了锚点变化对浏览器的历史记录也会影响,同时锚点的变化跟pushState也有一些关联.所以就花了点时间,把这两个东 ...
- JS操作DOM常用API总结
<JS高程>中的DOM部分写的有些繁琐,还没勇气整理,直到看到了这篇博文 Javascript操作DOM常用API总结,顿时有了一种居高临下,一览全局的感觉.不过有时间还是得自己把书里面的 ...
- 每次用 selenium 操作浏览器都还原了 (比如没有浏览器历史记录)
每次用 selenium 操作浏览器都还原了 (比如没有浏览器历史记录)
- 用 JavaScript 检测浏览器在线/离线状态(JavaScript API — navigator.onLine)
如今HTML5 移动应用或 Web app 中越来越普遍的使用了离线浏览技术,所以用 JavaScript 检测浏览器在线/离线状态非常常见. 无论浏览器是否在线,navigator.onLine 属 ...
- 使用 W3C Performance 对象通过 R 和 JavaScript 将浏览器内的性能数据可视化[转]
当考虑 Web 性能指标时,需要关注的目标数字应该是从您自己的用户那里获得的实际用户指标.最常见的方法是利用 Splunk 之类的工具来分析您的机器数据,该工具支持您分析和可视化您的访问权限和错误日志 ...
- JavaScript 客户端JavaScript之事件(DOM API 提供模块之一)
具有交互性的JavaScript程序使用的是事件驱动的程序设计模型. 目前使用的有3种完全不同的不兼容的事件处理模型. 1.原始事件模型 (一种简单的事件处理模式) 一般把它看作0级DOM API ...
随机推荐
- kubernetes:用label让pod在指定的node上运行(kubernetes1.18.3)
一,为什么要为node指定label? 通常scheduler会把pod调度到所有可用的Node,有的情况下我们希望能把 Pod 部署到指定的 Node, 例如: 有的Node上配备了速度更快的SSD ...
- centos8环境安装配置rsync
一,查看本地centos的版本: [root@localhost lib]# cat /etc/redhat-release CentOS Linux release 8.1.1911 (Core) ...
- C++ Primer第5版 第二章课后练习
练习2.1 C++ 语言规定short 和 int 至少 16 位, long 至少32位, long long 至少64位.带符号类型可以表示整数.负数或0, 无符号类型则仅能表示大于等于0的值Th ...
- Seaborn系列 | 散点图scatterplot()
散点图 解读 可以通过调整颜色.大小和样式等参数来显示数据之间的关系. 函数原型 seaborn.scatterplot(x=None, y=None, hue=None, style=None, s ...
- leaflet平台添加天地图方法
leaflet平台添加天地图得方法具体如下操作 var map = L.map('map', { crs: L.CRS.EPSG4326, zoomControl: true, edit ...
- python第三章:函数
在前面章节中,介绍了一些input(),print(),len()等内建函数,还有random,math等标准库相关函数,这些都是可以直接使用的,但是很多时候,我们也是可以编写自己的函数. 看个例子: ...
- Codeforces Round #427 (Div. 2) E. The penguin's game (交互题,二进制分组)
E. The penguin's game time limit per test: 1 second memory limit per test: 256 megabytes input: stan ...
- docker 启动mysql 挂载宿主机目录
在使用docker run 运行镜像获取容器时,有些容器会自动产生一些数据,为了这些数据会因为container (容器)的消失而消失,保证数据的安全,比如mysql 容器在运行中产生的一些表的数据, ...
- 虚拟机之kali2.0
kali2.0下载地址: 链接: https://pan.baidu.com/s/1CiQJNfvUPFw3aJR103XSbg 提取码: 57wp
- CyclicBarrier(循环栅栏)
CyclicBarrier public class CyclicBarrierDemo { public static void main(String[] args) { CyclicBarrie ...