首页 > 语言 > JavaScript > 正文

vue路由跳转时判断用户是否登录功能的实现

2024-05-06 15:46:18
字体:
来源:转载
供稿:网友

在webapp的开发过程中,我们经常要考虑到用户体验,我们经常设置不需要调用个人数据的页面供游客访问,今天就由错新技术频道小编给大家详细介绍vue路由跳转时判断用户是否登录功能的实现,大家要仔细阅读哦。

一丶首先在用户登录前后分别给出一个状态来标识此用户是否登录(建议用vuex);

简单用vuex表示一下,不会可以自己去官网多看看;

import Vue from ‘vue‘import Vuex from ‘vuex‘Vue.use(Vuex);var state = {  isLogin:0,     //初始时候给一个 isLogin=0 表示用户未登录};const mutations = {  changeLogin(state,data){    state.isLogin = data;  }};

二丶在用户登录时改变登录状态;

 this.$store.commit(‘changeLogin‘,‘100‘)    //登录后改变登录状态 isLogin = 100 ;

 

三丶重点来了;

在你的路由入口加上导航钩子,具体什么意思看代码;

一丶设置需要校验的路由

{ path: ‘/admin‘,   component: Admin,  meta:{auth:true} // 设置当前路由需要校验  不需要校验的路由就不用写了;不要问为什么,自己去看官网  }  

二丶路由跳转并校验

router.beforeEach((to,from,next) => {   if(to.matched.some( m => m.meta.auth)){     // 对路由进行验证     if(store.state.isLogin==‘100‘) { // 已经登陆       next()   // 正常跳转到你设置好的页面     }else{       // 未登录则跳转到登陆界面,query:{ Rurl: to.fullPath}表示把当前路由信息传递过去方便登录后跳转回来;       next({path:‘/login‘,query:{ Rurl: to.fullPath} })      }     }else{       next()   } })

以上所有内容就是错新技术频道小编介绍的vue路由跳转时判断用户是否登录功能的实现,我们需要选择哪种实现可以根据自身的需求进行操作。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选