首页 > 语言 > JavaScript > 正文

Vue登录注册并保持登录状态的方法

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

关于vue登录注册,并保持登录状态,是vue玩家必经之路,网上也有很多的解决方法,但是有一些太过于复杂,新手可能会看的一脸懵逼,现在给大家介绍一种我自己写项目在用而且并不难理解的一种方法。

项目中有一些路由是需要登录才可以进入的,比如首页,个人中心等等

有一些路由是不需要登录就可以进入,比如登录页,注册页,忘记密码等等

那如何判断路由是否需要登录呢?就要在路由JS里面做文章

在router.js中添加meta区分

比如登录注册页面,不需要登录即可进入,那么我们把meta中的isLogin标志设置为false

{ //登录 path: '/login', component: login, meta: {  isLogin: false }},{ //注册 path: '/register', component: register, meta: {  isLogin: false }},

而在首页我们需要登录才能进入,那么我们把meta中的isLogin标志设置为true

{ //首页 path: '/home', component: home, meta: {  isLogin: true },}

这样我们就为进入各个路由是否需要登录做了区分。

接下来我们在login.vue中修改登录后状态

我们使用axios向后台发起登录请求

this.$axios.post("/xxx/login", {user:name,password:pwd})  .then(data => {    //登录失败,先不讨论    if (data.data.status != 200) {     //iViewUi的友好提示     this.$Message.error(data.data.message);    //登录成功    } else {     //设置Vuex登录标志为true,默认userLogin为false     this.$store.dispatch("userLogin", true);     //Vuex在用户刷新的时候userLogin会回到默认值false,所以我们需要用到HTML5储存     //我们设置一个名为Flag,值为isLogin的字段,作用是如果Flag有值且为isLogin的时候,证明用户已经登录了。     localStorage.setItem("Flag", "isLogin");     //iViewUi的友好提示     this.$Message.success(data.data.message);     //登录成功后跳转到指定页面     this.$router.push("/home");    } });

Vuex里面我是这样写的(如果项目不需要Vuex,那么直接使用HTML5储存就可以了):

export const store = new Vuex.Store({ // 设置属性 state: {  isLogin: false, }, // 获取属性的状态 getters: {  //获取登录状态  isLogin: state => state.isLogin, }, // 设置属性状态 mutations: {  //保存登录状态  userStatus(state, flag) {   state.isLogin = flag  }, }, // 应用mutations actions: {  //获取登录状态  setUser({commit}, flag) {   commit("userStatus", flag)  }, }})

重点来了~,在mian.js里

router.beforeEach((to, from, next) => { //获取用户登录成功后储存的登录标志 let getFlag = localStorage.getItem("Flag"); //如果登录标志存在且为isLogin,即用户已登录 if(getFlag === "isLogin"){  //设置vuex登录状态为已登录  store.state.isLogin = true  next()  //如果已登录,还想想进入登录注册界面,则定向回首页  if (!to.meta.isLogin) {    //iViewUi友好提示   iView.Message.error('请先退出登录')   next({    path: '/home'   })  }  //如果登录标志不存在,即未登录 }else{  //用户想进入需要登录的页面,则定向回登录界面  if(to.meta.isLogin){   next({    path: '/login',   })   //iViewUi友好提示   iView.Message.info('请先登录')  //用户进入无需登录的界面,则跳转继续  }else{   next()  } }});router.afterEach(route => { window.scroll(0, 0);});            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选