JavaScript实现SPA的核心是利用history.pushState修改URL、监听popstate事件响应导航、动态匹配路由并更新DOM,需拦截a标签点击、服务端配置兜底返回index.html。
用 JavaScript 实现路由和单页应用(SPA),核心是监听 URL 变化、按需加载内容、避免整页刷新。不需要框架也能做到,关键是掌握 history.pushState、popstate 事件和 DOM 动态更新。
浏览器提供 window.history API 来操作导航记录,配合 pushState 和 replaceState 可以修改 URL 而不触发跳转。
history.pushState(state, title, url) 更新地址栏window.addEventListener('popstate', handler) 捕获浏览器前进/后退动作state 参数可传入任意对象,用于保存页面状态(比如当前页码、筛选条件)把 URL 路径映射到对应视图或处理函数,可用简单正则或更清晰的键值对方式:
{ '/': homePage, '/about': aboutPage, '/posts/:id': postDetail }
location.pathname,逐条比对:对带参数的路径(如 /posts/123),用正则提取 id 并传给渲染函数URLPattern(现代浏览器支持)做匹配,语义清晰且支持命名组每次路由切换,应卸载旧组件、加载新内容、更新 DOM,而不是简单地 innerHTML = ...:
import() 动态导入对应模块(实现代码分割)用户点击 时,默认会刷新页面——需要统一拦截:
#app)委托绑定 click 事件,判断目标是否为站内链接pushState + 手动渲染,再 event.preventDefault()
index.html),否则直接访问子路径会 404基本上就这些。不复杂但容易忽略细节,比如没监听 popstate 就无法响应后退键,或者没拦截 a 标
签导致意外刷新。写个小 demo 跑通一次,后面扩展功能(嵌套路由、守卫、懒加载)就顺了。