vue $router和$route的区别详解

下面是详细讲解“vue $router和$route的区别详解”的完整攻略:

背景

Vue.js 是一个轻量级的 MVVM 前端框架,常用的路由管理器是 vue-router。在使用 vue-router 过程中,可能会涉及到两个关键对象:$router 和 $route。这两个对象貌似很相似,但实际上有着明确的区别。本文将详细讲解两者的区别和应用场景。

$router

在 Vue.js 组件中,可以通过这个对象访问到 VueRouter 实例(路由管理器),从而可以方便地执行一些基于路由跳转的方法,如push, replace, go等,使用 $router 对象的优点:

  • $router 可以很方便地执行路由跳转的方法。
  • $router 对象仅用于在组件代码中调用路由方法,因此较为轻量。

示例:跳转到命名路径为/home的页面

// 通过 this.$router 访问路由(VueRouter实例)
this.$router.push({ name: 'home' });

$route

$route 是当前路由的信息对象,包含当前路由的路径、参数、查询参数等,使用 $route 对象的优点:

  • $route 是只读的,不支持修改。
  • $route 可以在 computed 中进行响应式更新,方便的获得当前路由变化后的信息。

示例:获取当前路径参数

// 通过 this.$route 访问当前路由信息
console.log(this.$route.params.id);

总结

$router 是 vue-router 的实例对象,提供了一些基于路由跳转的方法,如push, replace, go等。常用于在组件代码中执行路由跳转的方法。

$route 是当前路由的信息对象,包含当前路由的路径、参数、查询参数等。$route 是只读的,不支持修改,可以在 computed 中进行响应式更新,方便的获得当前路由变化后的信息。

除了上述区别,$router 和 $route 还有很多的实际应用场景,比如:

  • 在全局导航守卫中使用 $router 拦截路由跳转。
  • 在页面的 computed 中使用 $route 监听路由变化。
  • 在组件内部使用 $router 跳转路由,同时又使用 $route 获得当前路由信息。

这里只是简单举了几个例子,还有很多其它的应用场景,需要在实际业务场景中灵活运用。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:vue $router和$route的区别详解 - Python技术站

(0)
上一篇 2023年6月11日
下一篇 2023年6月11日

相关文章

  • UpdatePanel触发javascript脚本的方法附代码

    关于”UpdatePanel触发javascript脚本的方法”,我来详细讲解一下。 首先,我们需要了解一下UpdatePanel是什么。UpdatePanel在ASP.NET中是一个用来局部刷新页面的控件。当UpdatePanel中的内容需要更新时,ASP.NET会自动发送异步请求并更新指定部分的内容。而JavaScript脚本则是一种脚本语言,可以用来为…

    JavaScript 2023年6月10日
    00
  • 15位和18位身份证JS校验的简单实例

    下面我将为你详细讲解如何实现“15位和18位身份证JS校验的简单实例”。 校验15位和18位身份证简单实例 1. 判断身份证长度 在对身份证进行校验之前,需要先判断身份证长度是否合法。根据规定,15位身份证和18位身份证长度分别是15和18位。具体实现代码如下所示: function checkIdCard(idCard) { // 判断身份证长度 if (…

    JavaScript 2023年6月10日
    00
  • 浅谈react-router@4.0 使用方法和源码分析

    浅谈react-router@4.0使用方法和源码分析 简介 React-Router是在React上的一个强大路由器。它可以处理导航并使页面发生渐进式加载。React-Router@4相对于上一版本有了许多改进,如无需添加任何特定的MIXIN,以及更好的文档。 使用方法 在使用React-Router之前,你必须先安装它。你可以直接在终端中输入命令来进行安…

    JavaScript 2023年6月11日
    00
  • javascript表单是否为空验证方法

    当我们在网站开发中使用表单时,需要对用户输入进行验证,以确保数据的完整性和合法性。下面,我将为大家介绍一种实现JavaScript表单是否为空验证方法的攻略。 1. HTML表单 首先,我们需要在HTML文件中创建一个表单: <form> <label for="username">用户名:</label&g…

    JavaScript 2023年6月10日
    00
  • PHP中CURL的几个经典应用实例

    下面是详细讲解“PHP中CURL的几个经典应用实例”的完整攻略。 1. 什么是CURL? CURL是一种在网络通信中使用的工具,它支持多种网络协议,可以用来HTTP、FTP、SMTP等服务的客户端程序。在PHP中,可以使用CURL库来实现与远程服务器的数据传输。 2. 安装CURL扩展 在使用PHP中的CURL扩展之前,需要先安装CURL扩展,以确保PHP支…

    JavaScript 2023年6月11日
    00
  • 微信小程序按钮点击动画效果的实现

    下面是关于“微信小程序按钮点击动画效果的实现”的完整攻略: 简介 在微信小程序中,用户交互体验至关重要。为了增强用户的交互体验,为小程序中按钮添加点击动画效果是非常必要的。本节将详细讲解如何实现一个简单的点击动画效果。 实现步骤 1.添加点击事件 首先,我们需要为按钮添加一个点击事件,这个很简单,只需要在 WXML 文件中绑定点击事件即可: <view…

    JavaScript 2023年6月11日
    00
  • javascript中attribute和property的区别详解

    JavaScript中attribute和property的区别详解 在JavaScript中,我们通常会用到HTML元素的属性和属性值,这些信息可以通过attribute或property来获取。虽然它们很相似,但是它们之间还是有很大的区别的。 Attribute Attribute是HTML元素上出现的特性(比如id、class、name等),它们包含在…

    JavaScript 2023年6月10日
    00
  • JavaScript 对象不变性介绍

    JavaScript 对象不变性介绍 JavaScript 中对象的不变性指的是:对象一旦被创建后,就无法更改它的属性和方法,直到对象被销毁。这种特性可以帮助我们编写更为健壮的代码,提高代码的可维护性和可预测性。 实现对象不变性的主要方法有三种:使用 Object.freeze() 方法、使用 Object.seal() 方法,以及使用原型链来限制属性的增删…

    JavaScript 2023年5月18日
    00
合作推广
合作推广
分享本页
返回顶部