有关router.beforeEach()路由页面限制

        router.beforeEach() 也就可以叫全局前置守卫,主要在路由页面跳转前做的一些操作,最常用的场景:例如用户登录检验,没有登录,就不能进入某些页面,只有登录了之后才有权限查看某些页面,说白了就是路由拦截。

  主要分为四个步骤:1、npm命令引入router  2、route配置    3、在permission.js文件配置router.beforeEach()   4、main.js引入

 1、npm命令引入router

npm install vue-router@4

   2、route配置

import { createRouter, createWebHistory} from 'vue-router'
import HomeView from '../views/HomeView.vue'

import index from '../pages/index.vue'
import NotFound from '../pages/404.vue'
import LonginPage from '../pages/longin/longin_page.vue'

const router = createRouter({
  history: createWebHistory(import.meta.env.BASE_URL),
  routes: [
    {
      path: '/',
      component: index
    },
    {
      path: '/LonginPage',
      name: 'LonginPage',
      component: LonginPage
    },
    { 
      path: '/:pathMatch(.*)*', 
      name: 'NotFound', 
      component: NotFound},
    {
      path: '/about',
      name: 'about',
      // route level code-splitting
      // this generates a separate chunk (About.[hash].js) for this route
      // which is lazy-loaded when the route is visited.
      component: () => import('../views/AboutView.vue')
    }
  ]
})

export default router

3、在permission.js文件配置router.beforeEach() 

import router from "~/router"
import { getToken } from "~/composables/auth"
import { toast } from "~/composables/util"


// 全局前置守卫
router.beforeEach((to,from,next)=>{

    const token = getToken()

    // 没有登录,强制跳转回登录页
    if(!token && to.path != "/LonginPage"){
        toast("请先登录","error")
        return next({ path:"/LonginPage" })
    }

    // 防止重复登录
    if(token && to.path == "/LonginPage"){
        toast("请勿重复登录","error")
        return next({ path:from.path ? from.path : "/" })
    }

    next()
})

4、main.js引入

import './permission'

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值