Vue中$router,路由守卫beforeEach 的使用,以及 this.$router.push两种方式的区别

本文主要是介绍Vue中$router,路由守卫beforeEach 的使用,以及 this.$router.push两种方式的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、$router

在 Vue 实例内部,可以通过 $router 访问路由实例,即通过调用 this.$router.push进行连接跳转。

$router.push()传参的两种方式:

1、 this.$router.push({name:xx, params:{a:xx, b:xx}})//a, b是我们要传递给另一个页面的参数

       目标页面通过this.$route.params.a或this.$route.params.b来获取参数

2、this.$router.push({path:xx, query:{a:xx, b:xx}}) //a, b是我们要传递给另一个页面的参数

   目标页面通过this.$route.query.a或this.$route.query.b来获取参数

共同点:都能给跳转的目标页面传递参数

不同点:1、获取参数的方式不同     2、使用name-params的方式传递,参数不会显示到地址栏,而path-query则会,这个区别类似于post与get。

下图是login页面使用name-params传递参数:注意地址栏

下图是login页面使用path-query传递参数:注意地址栏

使用场景总结:name-params 可用于私密性有要求的情况,path-query则可以用于需要在地址栏显示参数的情况

官网有详细的用法解释. 链接:编程式的导航

 二、beforeEach的使用

使用场景: 一般用在跳转前需要做校验的地方,如:进入首页前做登录校验,如果已登录则跳转首页,否则跳转登录页。

使用的地方:

 如果是做跳转首页前做登录校验,需要写在main.js文件中,表示在所有路由被访问之前做校验;

import Vue from 'vue'
import App from './App'
import router from './router'
import config from './util/config'
import axios from 'axios'
import Cookies from 'js-cookie'
import iView from 'iview';
import 'iview/dist/styles/iview.css';import Home from './components/Home'
import Login from './components/login/login'Vue.use(iView);Vue.config.productionTip = false;
Vue.prototype.baseUrl = config.baseUrl;
Vue.prototype.$http = axios;
Vue.prototype.Cookies = Cookies;  //路由跳转前做判断
router.beforeEach((to, from, next) => {let hasLogin = Cookies.get('hasLogin'); //从cookies中获取是否已登陆过的信息if(hasLogin){next()}else{if(to.path == '/login'){next()}else{next({replace:true,name:'login',})}}
})/* eslint-disable no-new */
new Vue({el: '#app',router,components: { App },template: '<App/>'
})

在使用beforeEach中,会遇到两个问题:

1、访问指定页面出现无法加载的情况(也就是空白)

2、访问指定页面,出现无限循环的问题

问题代码如下:

router.beforeEach((to, from, next)=>{if(hasLogin){ //如果已经登录,则直接跳转next();}else if(to.name === 'Home'){ //如果未跳转,且访问的是首页,则重定向到登录页next({replace:false,name:'login'})}
})

这么写代码会有个问题,那就是当hasLogin为false时,访问任意页面都会出现空白,这是因为:

  • next() 表示路由成功,直接进入to路由,不会再次调用router.beforeEach()
  • next('login') 表示路由拦截成功,重定向至login,会再次调用router.beforeEach()

也就是说beforeEach()必须调用next(),否则就会出现无限循环,next() 和 next('xxx') 是不一样的,区别就是前者不会再次调用router.beforeEach(),后者会!!!

 官网相关说明:前置全局守卫

解决方法:

router.beforeEach((to, from, next)=>{if(hasLogin){ //如果已经登录,则直接跳转next();}else if(to.name === 'Home'){ //如果未跳转,且访问的是首页,则重定向到登录页next({replace:false,name:'login'})}else{next() //新增这一句}
})/*
理解:
当调用完next({name:'login'}),再次调用router.beforeEach()时,此时的to.name可能已经不在router.beforeEach()的条件判断中了,因此需要加上next(),告诉路由守卫,这种情况的继续执行,而不至于停留。*/

理解:
当调用完next({name:'login'}),再次调用router.beforeEach()时,此时的to.name可能已经不在router.beforeEach()的条件判断中了,因此需要加上next(),告诉路由守卫,这种情况的继续执行,而不至于停留。

 

这篇关于Vue中$router,路由守卫beforeEach 的使用,以及 this.$router.push两种方式的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/959577

相关文章

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H