微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

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

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

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

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

在router.js中添加Meta区分

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

rush:js;"> { //登录 path: '/login',component: login,Meta: { isLogin: false } },{ //注册 path: '/register',component: register,

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

rush:js;"> { //首页 path: '/home',component: home,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里

{

//获取用户登录成功后储存的登录标志
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")即可

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

原文地址:https://www.jb51.cc/vue/30919.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐