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 兼容性更强,适合旧浏览器。

相关推荐
加班是不可能的,除非双倍日工资2 小时前
css预编译器实现星空背景图
前端·css·vue3
wyiyiyi3 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
gnip3 小时前
vite和webpack打包结构控制
前端·javascript
excel4 小时前
在二维 Canvas 中模拟三角形绕 X、Y 轴旋转
前端
阿华的代码王国4 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
一条上岸小咸鱼4 小时前
Kotlin 基本数据类型(三):Booleans、Characters
android·前端·kotlin
Jimmy4 小时前
AI 代理是什么,其有助于我们实现更智能编程
前端·后端·ai编程
ZXT4 小时前
promise & async await总结
前端
Jerry说前后端4 小时前
RecyclerView 性能优化:从原理到实践的深度优化方案
android·前端·性能优化
画个太阳作晴天4 小时前
A12预装app
linux·服务器·前端