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

如何用Javascript实现路由功能?

夢幻星辰
发布: 2025-12-16 22:15:40
原创
701人浏览过
前端路由核心是监听URL变化、解析路径、匹配规则并动态渲染,关键用history.pushState、popstate事件和路径解析逻辑,需手动触发首次匹配并处理404与服务端配置。

如何用javascript实现路由功能?

用 JavaScript 实现前端路由,核心是监听 URL 变化、解析路径、匹配规则、动态渲染对应内容——不依赖框架也能做到,关键是掌握 history.pushStatepopstate 事件和 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免费学习笔记(深入)”;

dmSOBC SHOP网店系统
dmSOBC SHOP网店系统

dmSOBC SHOP网店系统由北京时代胜腾信息技术有限公司(http://www.webzhan.com)历时6个月开发完成,本着简单实用的理念,商城在功能上摒弃了外在装饰的一些辅助功能,尽可能的精简各项模块开发,做到有用的才开发,网店V1.0.0版本开发完成后得到了很多用户的使用并获得了好评,公司立即对网店进行升级,其中包括修正客户提出的一些意见和建议,现对广大用户提供免费试用版本,如您在使用

dmSOBC SHOP网店系统 0
查看详情 dmSOBC SHOP网店系统
<font size="2"><pre class="brush:php;toolbar:false;">class SimpleRouter {
  constructor(routes) {
    this.routes = routes;
    this.init();
  }
  init() {
    window.addEventListener('popstate', () => this.route());
    this.route(); // 首次加载
  }
  route() {
    const path = location.pathname;
    const match = Object.keys(this.routes).find(key => {
      const regex = ^${key.replace(/:(\w+)/g, '([^/]+)')}$;
      return regex.test(path);
    });
    if (match) {
      const args = path.match(new RegExp(^${match.replace(/:(\w+)/g, '([^/]+)')}$));
      this.routes[match](args?.slice(1) || []);
    } else {
      this.routes['*']?.();
    }
  }
  go(path) {
    history.pushState(null, '', path);
    this.route();
  }
}
登录后复制

使用:new SimpleRouter({ '/': renderHome, '/user/:id': ([id]) => renderUser(id) })

处理锚点与 404

真实项目中要兼顾边界情况:

  • 忽略 hash(如 #section1):只取 location.pathname,别用 location.href
  • 未匹配路径:加一个 '*' 通配符路由,显示 404 页面
  • 服务端配合:部署时确保所有路由都返回 index.html(否则直接访问 /admin 会 404)

基本上就这些。不复杂但容易忽略首次加载和 history 状态管理——写完记得测一下点击链接、浏览器前后按钮、直接输入 URL 这三种场景是否都正常。

以上就是如何用Javascript实现路由功能?的详细内容,更多请关注php中文网其它相关文章!

路由优化大师
路由优化大师

路由优化大师是一款及简单的路由器设置管理软件,其主要功能是一键设置优化路由、屏广告、防蹭网、路由器全面检测及高级设置等,有需要的小伙伴快来保存下载体验吧!

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

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