面试必备:前端路由 route 和 router 的核心要点

前言

在前端开发中,路由是实现单页面应用(SPA)的核心机制之一。然而,很多新手开发者在学习路由时,常常会混淆 routerouter 的概念。

今天,我们就来深入探讨一下这两个概念的区别,并通过代码示例来加深理解。

一、为什么容易混淆?

routerouter 都是路由相关的核心概念,但它们的作用和使用场景完全不同。router 是路由的管理者,而 route 是当前激活的路由对象。在实际开发中,如果不理解它们的区别,很容易在代码中出错,甚至在面试中被问到时也答不上来。

二、一句话总结

  • router(路由器) :是路由的管理者,负责整个路由的跳转、拦截、传参等操作。
  • route(路由信息) :是当前激活的路由对象,存储当前页面的路径、参数、查询参数等信息。

三、代码实战

1. Vue 中的 routerroute

在 Vue 中,router 是全局路由管理器,而 route 是当前激活的路由对象。以下是一个简单的代码示例:

javascript 复制代码
// 定义路由规则
const routes = [
  { path: '/home', component: Home },
  { path: '/about', component: About },
  { path: '/user/:id', component: User }
];

// 创建路由实例
const router = createRouter({
  history: createWebHistory(),
  routes
});

// 在组件中使用 router
export default {
  methods: {
    goToHome() {
      // 使用 router.push() 跳转到首页
      this.$router.push('/home');
    },
    goToUser(id) {
      // 使用 router.push() 跳转到用户页面
      this.$router.push(`/user/${id}`);
    }
  }
};

在上述代码中,router 是通过 createRouter 创建的路由管理器,它负责管理所有的路由规则。在组件中,我们通过 this.$router 来调用路由管理器的方法,例如 pushreplacego

route 是当前激活的路由对象,可以通过 this.$route 访问。例如:

javascript 复制代码
export default {
  created() {
    // 获取当前路由信息
    console.log(this.$route.path);    // 当前路径,例如 "/user/123"
    console.log(this.$route.params); // 动态参数,例如 { id: "123" }
    console.log(this.$route.query);   // 查询参数,例如 ?name=小杨 → { name: "小杨" }
  }
};

在上述代码中,this.$route 是当前激活的路由对象,它包含了当前页面的路径、动态参数和查询参数等信息。

2. React 中的类似概念

在 React 中,虽然没有 $router$route,但概念是相通的。React Router 提供了 useNavigateuseLocationuseParams 等钩子来实现类似的功能。

javascript 复制代码
import { useNavigate, useLocation, useParams } from 'react-router-dom';

function MyComponent() {
  const navigate = useNavigate(); // 相当于 this.$router
  const location = useLocation(); // 相当于 this.$route
  const params = useParams();     // 相当于 this.$route.params

  const goToHome = () => {
    navigate('/home'); // 相当于 this.$router.push('/home')
  };

  return (
    <div>
      当前路径:{location.pathname} <br />
      参数:{params.id}
    </div>
  );
}

在上述代码中,useNavigate 是 React Router 提供的钩子,用于实现路由跳转,类似于 Vue 中的 this.$routeruseLocationuseParams 分别用于获取当前路由信息和动态参数,类似于 Vue 中的 this.$routethis.$route.params

四、常见误区与面试题

1. this.$routerthis.$route 能互换吗?

不能!

  • this.$router 是路由管理器,负责跳转、拦截等操作。
  • this.$route 是当前路由信息,只读数据,不能用于跳转。

2. 为什么动态路由要用 params,而查询参数用 query

  • params (如 /user/:id):是路由的一部分,适合 SEO 和短链接。
  • query (如 ?name=小杨):是额外参数,不影响路由匹配。

3. 编程式导航能用 <router-link> 替代吗?

可以,但场景不同:

  • <router-link>:在模板中使用(类似 <a> 标签)。
  • this.$router.push():在 JS 逻辑中使用(例如登录后跳转)。

五、总结

对比项 router route
作用 路由管理(跳转、拦截) 当前路由信息(路径、参数)
类比 快递公司调度中心 你手里的快递单
Vue this.$router this.$route
React useNavigate() useLocation()

记住口诀:

  • router 管跳转,route 管信息
  • 跳转找 router,参数找 route

希望这篇文章能帮助你更好地理解前端路由中的 routerouter 的区别。如果你在开发中遇到任何问题,欢迎随时交流!

相关推荐
华洛几秒前
落地AI产品的最后一步:微调(面向非LLM算法工程师)
前端·aigc·产品经理
成小白5 分钟前
前端实现两个页面之间的通讯
前端·javascript
啷咯哩咯啷14 分钟前
element-plus el-tree-v2大数据量勾选节点卡顿问题
前端·javascript·vue.js
阳光阴郁大boy1 小时前
一个基于纯前端技术实现的五子棋游戏,无需后端服务,直接在浏览器中运行。
前端·游戏
石小石Orz1 小时前
效率提升一倍!谈谈我的高效开发工具链
前端·后端·trae
EndingCoder1 小时前
测试 Next.js 应用:工具与策略
开发语言·前端·javascript·log4j·测试·全栈·next.js
xw51 小时前
免费的个人网站托管-PinMe篇
服务器·前端
!win !1 小时前
免费的个人网站托管-PinMe篇
前端·前端工具
牧天白衣.1 小时前
CSS中linear-gradient 的用法
前端·css
军军3602 小时前
Git大型仓库的局部开发:分步克隆 + 指定目录拉取
前端·git