vue路由跳转时判断用户是否登录功能的实现
2017-10-26 10:04
1031 查看
通过判断该用户是否登录过,如果没有登录则跳转到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路由跳转时判断用户是否登录功能的实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 使用vue-router beforEach实现判断用户登录跳转路由筛选功能
- vue路由跳转时 判断用户是否处于 登录状态
- angular2 HttpClient判断用户是否登录,来控制路由的跳转
- vue-router路由跳转判断用户是否存在
- 使用vue-route 的 beforeEach 实现导航守卫(路由跳转前验证登录)功能
- axios 拦截 , 页面跳转, token 验证(经常用于判断用户是否登录)
- react-navigation 如何判断用户是否登录跳转到登录页的方法
- Vue-router路由判断页面未登录跳转到登录页面的实例
- PHP判断用户是否已经登录(跳转到不同页面或者执行不同动作)
- angularjs给Model添加拦截过滤器,路由增加限制,实现用户登录状态判断
- 判断用户是否登录,如果登录了放行,否则跳转到登陆页面
- vue.js在laravel框架中的拦截器 ( axios)的使用--实现判断用户登录
- asp.net mvc 实现判断用户是否登录的两种方式
- AngularJS实现用户登录状态判断的方法(Model添加拦截过滤器,路由增加限制)
- 判断用户是否已登录,未登录用户禁止访问任何页面或action,自动跳转到登录页面
- angularjs给Model添加拦截过滤器,路由增加限制,实现用户登录状态判断
- react-navigation 如何判断用户是否登录跳转到登录页
- AngularJS实现用户登录状态判断的方法(Model添加拦截过滤器,路由增加限制)
- vue 利用路由守卫判断是否登录的方法
- ionic1 跳转至某个页面之前判断用户是否登录