Vue登录注册并保持登录状态的方法
程序员文章站
2022-06-24 16:26:06
关于vue登录注册,并保持登录状态,是vue玩家必经之路,网上也有很多的解决方法,但是有一些太过于复杂,新手可能会看的一脸懵逼,现在给大家介绍一种我自己写项目在用而且并不难...
关于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); });
这样就已经完成了vue的登录注册,当用户关闭浏览器或者第二天再次进入网站,用户依旧可以保持着登录的状态直到用户手动退出登录。
tips:用户退出只需要localstorage.removeitem("flag")即可
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。