为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

哈士奇WWW 2019-01-03 02:02:57
vue路由跳转时判断用户是否登录功能
查看完整描述

1 回答

?
萧十郎

TA贡献1815条经验 获得超13个赞

一丶首先在用户登录前后分别给出一个状态来标识此用户是否登录(建议用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;
}
};
复制代码
二丶在用户登录时改变登录状态;
1
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()
}
})



查看完整回答
1 反对 回复 2019-01-06
  • 我好菜的
    我好菜的
    很有用,我按照别人的案例打了一遍,但是有些地方不太懂,层主的注释给了我很大帮助,谢谢。
  • 1 回答
  • 0 关注
  • 3012 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信