SPA是如何通过js不刷新页面但是更新浏览器的url的?

不刷新页面但更新浏览器 URL 的两种方式

概述

在不刷新页面的情况下更新浏览器 URL,可以通过两种方式实现:

  1. History API :通过 history.pushState()history.replaceState() 间接更改 URL。
  2. Hash Routing :通过修改 URL 的 hash 直接更改 URL。

两种方式的本质都是更改 URL,但 History API 更现代且 URL 更简洁,而 Hash Routing 兼容性更好,适合旧浏览器。


1. 通过 History API

参考MDN History API

更改 URL

使用以下 API 更改 history 对象:

  • history.pushState(state, unused, url):添加新历史记录。
  • history.replaceState(state, unused, url):替换当前历史记录。

历史导航

使用以下方法进行历史记录的前进和回退:

  • history.back():回退到上一个历史记录。
  • history.forward():前进到下一个历史记录。
  • history.go(delta):跳转到指定历史记录。

UI 更新

  • pushStatereplaceState 不会触发页面刷新或事件,因此需要手动更新 UI。

2. 通过 URL Hash

更改 URL

通过 location.hash 直接修改 URL 的 hash 部分:

javascript 复制代码
location.hash = 'hashValue';

UI 更新

  • 手动更新 UI,或通过监听 hashchange 事件自动更新 UI:
javascript 复制代码
window.addEventListener('hashchange', () => {
    console.log('Hash changed:', location.hash);
});

自定义前进后退

  • 需要手动维护两个栈(backStackforwardStack)来存储 hash 的变化历史。

对比与选择

  • History API:更现代,URL 更简洁,但需要手动更新 UI。
  • Hash Routing :兼容性更好,适合旧浏览器,但 URL 中包含 #

总结

通过 History API 和 Hash Routing,可以在不刷新页面的情况下更新浏览器 URL。History API 适合现代应用,而 Hash Routing 兼容性更强,适合旧浏览器。

相关推荐
袋鼠云数栈UED团队6 小时前
一套 Spec-First 的 AI 编程工作流
前端·人工智能
袋鼠云数栈前端6 小时前
一套 Spec-First 的 AI 编程工作流
前端·ai+
angerdream6 小时前
Android手把手编写儿童手机远程监控App之vue3 路由守卫
前端
不服老的小黑哥6 小时前
AI规范驱动编程-harness工程项目实战
前端
vivo互联网技术6 小时前
从 Web 到桌面:基于 Tauri 2.0 + Vue 3 打造 vivo 线下门店「大头贴」拍照体验系统
前端·rust
光影少年6 小时前
React 合成事件机制、和原生事件区别、事件冒泡阻止
前端·react.js·掘金·金石计划
没有鸡汤吃不下饭6 小时前
告别手动对接口:我用 OpenAPI JSON 做了一个前端接口同步 Skill
前端·ai编程
空栈独白6 小时前
NestJS实战-前后端联调
前端
米饭同学i6 小时前
浏览器记住密码导致忘记密码页面输入框回显错乱?看这篇就够了
前端
孤舟望月6 小时前
NestJS实战-后端开发-全局配置
前端