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

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

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

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

rush:xhtml;"> 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;
}

};

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

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

三丶重点来了;

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

一丶设置需要校验的路由

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

}

二丶路由跳转并校验

{

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路由跳转时判断用户是否登录功能的实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。

相关文章

可以通过min-width属性来设置el-table-column的最小宽度。以...
yarn dev,当文件变动后,会自动重启。 yanr start不会自动重...
ref 用于创建一个对值的响应式引用。这个值可以是原始值(如...
通过修改 getWK005 函数来实现这一点。这里的 query 参数就是...
<el-form-item label="入库类型" ...
API 变动 样式类名变化: 一些组件的样式类名有所变动,可能需...