Vue登录注册并保持登录状态的方法
关于vue登录注册,并保持登录状态,是vue玩家必经之路,网上也有很多的解决方法,但是有一些太过于复杂,新手可能会看的一脸懵逼,现在给大家介绍一种我自己写项目在用而且并不难理解的一种方法。 项目中有一些路由是需要登录才可以进入的,比如首页,个人中心等等 有一些路由是不需要登录就可以进入,比如登录页,注册页,忘记密码等等 那如何判断路由是否需要登录呢?就要在路由JS里面做文章 在router.js中添加meta区分 比如登录注册页面,不需要登录即可进入,那么我们把meta中的isLogin标志设置为false 而在首页我们需要登录才能进入,那么我们把meta中的isLogin标志设置为true 这样我们就为进入各个路由是否需要登录做了区分。 接下来我们在login.vue中修改登录后状态我们使用axios向后台发起登录请求 {
//登录失败,先不讨论
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储存就可以了): state.isLogin,// 设置属性状态
mutations: {
//保存登录状态
userStatus(state,flag) {
state.isLogin = flag
},// 应用mutations
actions: {
//获取登录状态
setUser({commit},flag) {
commit("userStatus",flag)
},}
})
重点来了~,在mian.js里 {
//获取用户登录成功后储存的登录标志 //如果登录标志存在且为isLogin,即用户已登录 //设置vuex登录状态为已登录 //如果已登录,还想想进入登录注册界面,则定向回首页 //如果登录标志不存在,即未登录 //用户想进入需要登录的页面,则定向回登录界面 } }); router.afterEach(route => { 这样就已经完成了Vue的登录注册,当用户关闭浏览器或者第二天再次进入网站,用户依旧可以保持着登录的状态直到用户手动退出登录。 Tips:用户退出只需要localStorage.removeItem("Flag")即可 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |