码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2017-07-17 18:37:32      阅读:6397      评论:0      收藏:0      [点我收藏+]

标签:logs   login   hang   outer   from   登陆   表示   mit   校验   

通过判断该用户是否登录过,如果没有登录则跳转到login登录路由,如果登录则正常跳转。

  一丶首先在用户登录前后分别给出一个状态来标识此用户是否登录(建议用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路由跳转时判断用户是否登录功能

标签:logs   login   hang   outer   from   登陆   表示   mit   校验   

原文地址:http://www.cnblogs.com/szyblogs/p/7196611.html

(19)
(6)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!