前端路由核心是监听URL变化、解析路径、匹配规则并动态渲染,关键用history.pushState、popstate事件和路径解析逻辑,需手动触发首次匹配并处理404与服务端配置。

用 JavaScript 实现前端路由,核心是监听 URL 变化、解析路径、匹配规则、动态渲染对应内容——不依赖框架也能做到,关键是掌握 history.pushState、popstate 事件和 URL 解析逻辑。
监听浏览器地址栏变化
单页应用(SPA)不能靠刷新跳转,得用 History API 操作路由状态:
- 用
history.pushState(state, title, url)替换当前 URL(不触发刷新),比如pushState(null, '', '/about') - 监听
window.addEventListener('popstate', handler)捕获后退/前进操作 - 首次加载时别忘了手动执行一次路由匹配(
popstate不会触发页面初始加载)
解析路径并匹配路由规则
把 URL 路径(location.pathname)和预定义的路由表比对,支持静态路径和简单参数:
- 静态匹配:
if (path === '/home') renderHome() - 带参数:用正则或
URLPattern(较新,兼容性注意)提取,例如/user/:id→ 匹配/user/123,取到id = '123' - 推荐用对象映射:
{ '/': homeHandler, '/post/:id': postHandler },遍历时用path.startsWith或正则测试
实现简易 Router 类(可直接用)
封装成类更易复用,内部管理路由表、监听、跳转方法:
立即学习“Java免费学习笔记(深入)”;
标签: javascript java html 前端 go 浏览器 路由 win
还木有评论哦,快来抢沙发吧~