记录一下全局路由守卫的使用;

  方法一:定义一个数组用于检测与管理需要登录的页面,全局路由守卫配合本地存储判断是否跳转

import Vue from 'vue'
import Router from 'vue-router'
import store from './../store' import Home from 'components/home/home' // 主页组件 // 其它组件... import Cart from 'components/cart/cart' // 购物车组件
import User from 'components/user/user' // 用户中心组件 // 其他组件... import GoodsDetail from 'components/goods-detail/goods-detail' // 商品详情组件 import { localTake } from 'common/js/localStore' // 本地存储方法封装 Vue.use(Router) const router = new Router({
routes: [
{
path: '/', // 默认地址
redirect: '/home'
},
{
path: '/home',
component: Home,
name: 'Home',
meta: {
title: '主页',
keepAlive: true // 需要被缓存
}
},
{
path: '/cart',
component: Cart,
name: 'Cart',
meta: {
title: '购物车',
keepAlive: true // 需要被缓存
}
},
{
path: '/user',
component: User,
name: 'User',
meta: {
title: '我的',
keepAlive: true // 需要被缓存
}
},
{
path: '/user-login',
component: UserLogIn,
name: 'UserLogIn',
meta: {
title: '登录',
keepAlive: false // 不需要被缓存
}
},
{
path: '/goods-detail',
component: GoodsDetail,
name: 'GoodsDetail',
meta: {
title: '商品详情',
keepAlive: true // 需要被缓存
}
}
],
scrollBehavior (to, from, savedPosition) {
if (savedPosition) {
return savedPosition
} else {
return {x: 0, y: 0}
}
}
}) // 全局路由守卫
router.beforeEach((to, from, next) => {
const nextRoute = ['User', 'Cart', 'GoodsDetail'] // 需要登录的页面
let isLogin = localTake('userMsg') // 判断是否登录,本地存储有用户数据则视为已经登录
// 未登录状态;当路由到 nextRoute 指定页时,跳转至 UserLogIn
if (nextRoute.indexOf(to.name) >= 0) { // 检测是否登录的页面
if (!isLogin) { // 如果未登录(本地存储无用户数据),并且要跳到登录页面
if (from.name === 'UserLogIn') {
next('/')
return
}
    // 登录后,跳到到当前页面
router.push({
name: 'UserLogIn',
params: {redirect: to.fullPath}
})
}
}
// 已登录状态;当路由到 UserLogIn 时,跳转至 Home
if (to.name === 'UserLogIn') {
if (isLogin) {
next('/')
return
}
}
next() // 必须使用 next ,执行效果依赖 next 方法的调用参数
}) export default router

  方法二:通过定义to.meta.needLogin(needLogin 为自定义,路由元信息),判断是否需要登录

import Vue from 'vue'
import Router from 'vue-router'
import store from './../store' import Home from 'components/home/home' // 主页组件 // 其它组件... import Cart from 'components/cart/cart' // 购物车组件
import User from 'components/user/user' // 用户中心组件 // 其他组件... import GoodsDetail from 'components/goods-detail/goods-detail' // 商品详情组件 import { localTake } from 'common/js/localStore' // 本地存储方法封装 Vue.use(Router)
const router = new Router({
routes: [
{
path: '/', // 默认地址
redirect: '/home'
},
{
path: '/home',
component: Home,
name: 'Home',
meta: {
title: '主页',
keepAlive: true // 需要被缓存
}
},
{
path: '/cart',
component: Cart,
name: 'Cart',
meta: {
title: '购物车',
keepAlive: true, // 需要被缓存
needLogin: true // 需要登录 
}
},
{
path: '/user',
component: User,
name: 'User',
meta: {
title: '我的',
keepAlive: true, // 需要被缓存
needLogin: true // 需要登录
}
},
{
path: '/user-login',
component: UserLogIn,
name: 'UserLogIn',
meta: {
title: '登录',
keepAlive: false // 不需要被缓存
}
},
{
path: '/goods-detail',
component: GoodsDetail,
name: 'GoodsDetail',
meta: {
title: '商品详情',
keepAlive: true, // 需要被缓存
needLogin: true // 需要登录
}
}
]
})
// 全局路由守卫
router.beforeEach((to, from, next) => {
let isLogin = localTake('userMsg')
if (to.meta.needLogin) { // 判断该路由是否需要登录权限
if (isLogin) { // 判断是否已经登录
next()
}
else {
next({
path: '/login',
query: {redirect: to.fullPath} // 将跳转的路由path作为参数,登录成功后跳转到该路由
})
}
}
else {
next()
}
}) export default router

推荐使用判断路由元信息的方法,代码比较简洁,能更好的维护与管理

Vue router 全局路由守卫的更多相关文章

  1. vue全局路由守卫beforeEach+token验证+node

    在后端安装jsonwebtoken         npm i jsonwebtoken --save 在 login.js文件中引入      // 引入jwtconst jwt = require ...

  2. Vue router 一个路由对应多个视图

    使用命名路由 https://jsfiddle.net/posva/6du90epg/ <script src="https://unpkg.com/vue/dist/vue.js&q ...

  3. Vue 中的Vue Router一级路由,二级路由,三级路由以及跳转

    今天编写了一下Vue中的路由 先用命令行新建一个空的项目,并且我知道要用路由,就下载了路由的相关依赖 vue init webpack demo5 完毕之后进入所在的项目 cd demo5 之后用vs ...

  4. vue全局路由守卫beforeEach

    在main.js里使用方法 router.beforeEach((to,from,next)=>{}) to,是将要跳转的路由, from,是离开的路由 next是个方法,判断to.path 或 ...

  5. 5分钟学会vue中的路由守卫(导航守卫)

    在项目开发中每一次路由的切换或者页面的刷新都需要判断用户是否已经登录,前端可以判断,后端也会进行判断的,我们前端最好也进行判断. vue-router提供了导航钩子:全局前置导航钩子 beforeEa ...

  6. vue router动态路由

    <div id="#app"> <router-link to="/user/header">路由1</router-link&g ...

  7. vue router引入路由与路由配置容易犯错的地方与常见的报错与处理报错

    首先npm安装vue-router插件,就不说了其次: 先看下我本地的目录结构吧 第一步:在src目录下新建一个专门存放router的index.js文件里面的内容为: import Vue from ...

  8. Vue 2.0 路由全局守卫

    vue2.0 实现导航守卫(路由守卫) 路由跳转前做一些验证,比如登录验证,是网站中的普遍需求. 对此,vue-route 提供的 beforeRouteUpdate 可以方便地实现导航守卫(navi ...

  9. vue路由守卫应用,监听是否登录

    路由跳转前做一些验证,比如登录验证,是网站中的普遍需求. 对此,vue-route 提供的 beforeRouteUpdate 可以方便地实现导航守卫(navigation-guards). 导航守卫 ...

随机推荐

  1. versionCode & versionName

    [versionCode & versionName] Android的版本可以在androidmainfest.xml中定义,主要有android:versionCode和android:v ...

  2. stevedore动态加载模块

    stevedore动态加载模块,stevedore使用setuptools的entry points来定义并加载插件.entry point引用的是定义在模块中的对象,比如类.函数.实例等,只要在im ...

  3. WAS 常见报错

    1) An error occurred while deleting the server. ADMG0011E: An unexpected exception occurred com.ibm. ...

  4. Wasserstein距离

    https://blog.csdn.net/leviopku/article/details/81388306 https://blog.csdn.net/nockinonheavensdoor/ar ...

  5. CardView 卡片布局

    转自:https://www.baidu.com/link?url=WwHvfX3PB_egfQ6GFwxsDeq4NDzB2AW-zaTzskkNXs0qWnIcHyh3pN3Oqe6YO1lAmV ...

  6. MYSQL之水平分区----MySQL partition分区I(5.1)

    一.        分区的概念 二.        为什么使用分区?(优点) 三.        分区类型 四.        子分区 五.        对分区进行修改(增加.删除.分解.合并) 六 ...

  7. ubuntu下安装redis及常用操作

    reids是一个内存数据库,具有存取速度快,使用简单等优点.我们常常在分布式或者负载均衡的系统中使用它来缓存一些公用的且不是很大量的数据,比如session或者各类token(比如微信的access_ ...

  8. iPhone X系列 的获取 - 安全区顶部和底部高度

    ///1. 获得当前窗口 var JY_WINDOW: UIWindow? { get{ if let app = UIApplication.shared.delegate as? AppDeleg ...

  9. Mybatis常用标签使用

    trim元素的主要功能是可以在自己包含的内容前加上某些前缀,也可以在其后加上某些后缀,与之对应的属性是prefix和suffix:可以把包含内容的首部某些内容覆盖,即忽略,也可以把尾部的某些内容覆盖, ...

  10. 绝对路径${pageContext.request.contextPath}

    ${pageContext.request.contextPath}用于解决使用相对路径时出现的问题,它的作用是取出所部署项目的名字. 如图,${pageContext.request.context ...