首页 > web前端 > js教程 > 正文

javascript历史记录API是什么_如何操作浏览器的历史栈?

夜晨
发布: 2025-12-21 14:52:02
原创
734人浏览过
History API 通过 history.pushState() 和 replaceState() 实现无刷新 URL 变更与历史管理,配合 popstate 事件监听导航,支持 SPA 的前进/后退体验;需注意同源限制、state 持久化及刷新兜底。

javascript历史记录api是什么_如何操作浏览器的历史栈?

JavaScript 历史记录 API(History API)是一组允许脚本操作浏览器会话历史的接口,核心是 history 对象。它让你能在不刷新页面的前提下,改变 URL、添加或替换历史条目,从而实现单页应用(SPA)中的“前进/后退”体验。

history.pushState():往历史添加新记录

调用 pushState() 会在当前会话历史中新增一条记录,同时更新地址栏 URL(可跨路径),但不会触发页面跳转或重新加载。

语法:
history.pushState(state, title, url)

  • state:一个可序列化的对象,随该历史条目一起保存,后续通过 popstate 事件可读取
  • title:目前大多数浏览器忽略此参数,传空字符串或 null 即可
  • url:新的相对或绝对 URL,必须同源(协议+域名+端口一致),否则报错

例如:
history.pushState({page: 'detail', id: 123}, '', '/post/123');
执行后地址栏变为 /post/123,用户点「后退」会回到上一条记录。

history.replaceState():替换当前历史记录

pushState() 类似,但不新增条目,而是直接修改当前历史项的 state 和 URL。

立即学习Java免费学习笔记(深入)”;

适用场景:表单提交后修正 URL,或初始化时同步 URL 与视图状态(避免多按一次后退回到空白页)。

Quicktools Background Remover
Quicktools Background Remover

Picsart推出的图片背景移除工具

Quicktools Background Remover 31
查看详情 Quicktools Background Remover

例如:
history.replaceState({page: 'home'}, '', '/');

监听 history 变化:popstate 事件

当用户点击浏览器「前进」「后退」按钮,或调用 history.back()/history.forward() 时,若目标历史项由 pushStatereplaceState 创建,则触发 popstate 事件。

注意:
- 页面首次加载、或通过普通链接跳转产生的历史项,不会触发 popstate
- 事件对象的 state 属性即当时传入的 state 对象

示例:

window.addEventListener('popstate', (event) => {
  const { state } = event;
  if (state?.page === 'detail') {
    renderDetail(state.id);
  }
});
登录后复制

其他实用方法

  • history.back():等价于点击浏览器后退按钮
  • history.forward():等价于点击前进按钮
  • history.go(n):跳转到历史栈中第 n 条记录(n=0 刷新,n=-1 后退一页)
  • history.length:只读属性,返回当前会话历史条目总数(含当前页)

⚠️ 注意:length 不代表可后退步数;且隐私模式下可能受限或返回固定值(如 1)。

基本上就这些。History API 不复杂但容易忽略 state 的合理设计和 popstate 的边界处理——比如页面刷新后 state 丢失,需结合 URL 解析做兜底恢复。

以上就是javascript历史记录API是什么_如何操作浏览器的历史?的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号