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


Posted in Javascript onAugust 17, 2018

关于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")即可

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery图片滚动放大代码分享(2)
Aug 28 Javascript
jQuery实现的仿百度分页足迹效果代码
Oct 30 Javascript
javascript实现方法调用与方法触发小结
Mar 26 Javascript
Vue.js每天必学之组件与组件间的通信
Sep 08 Javascript
bootstrap警告框示例代码分享
May 17 Javascript
Vue 监听列表item渲染事件方法
Sep 06 Javascript
深入浅析Vue 中 ref 的使用
Apr 29 Javascript
在vue项目中使用codemirror插件实现代码编辑器功能
Aug 27 Javascript
Vue学习笔记之计算属性与侦听器用法
Dec 07 Javascript
微信小程序中的video视频实现 自定义播放按钮、封面图、视频封面上文案
Jan 02 Javascript
在微信小程序中渲染HTML内容3种解决方案及分析与问题解决
Jan 12 Javascript
微信小程序实现点击导航条切换页面
Nov 19 Javascript
小程序清理本地缓存的方法
Aug 17 #Javascript
layui table设置前台过滤转义等方法
Aug 17 #Javascript
详解小程序缓存插件(mrc)
Aug 17 #Javascript
layui 设置table 行的高度方法
Aug 17 #Javascript
微信小程序数据分析之自定义分析的实现
Aug 17 #Javascript
jQuery实现的页面弹幕效果【测试可用】
Aug 17 #jQuery
layui的table中显示图片方法
Aug 17 #Javascript
You might like
收藏的PHP常用函数 推荐收藏保存
2010/02/21 PHP
PHP递归返回值时出现的问题解决办法
2013/02/19 PHP
destoon后台网站设置变成空白的解决方法
2014/06/21 PHP
ucenter通信原理分析
2015/01/09 PHP
php计算到指定日期还有多少天的方法
2015/04/14 PHP
PHP检测用户是否关闭浏览器的方法
2016/02/14 PHP
php解决和避免form表单重复提交的几种方法
2016/08/31 PHP
PHP网页安全认证的实例详解
2017/09/28 PHP
PHP常用的类封装小结【4个工具类】
2019/06/28 PHP
jquery 1.4.2发布!主要是性能与API
2010/02/25 Javascript
JS选项卡动态替换banner图片路径的方法
2015/05/11 Javascript
javascript实现textarea中tab键的缩排处理方法
2015/06/26 Javascript
jquery实现简单合拢与展开网页面板的方法
2015/09/01 Javascript
jquery+css3实现会动的小圆圈效果
2016/01/27 Javascript
jQuery Ajax和getJSON获取后台普通json数据和层级json数据用法分析
2016/06/08 Javascript
JS实现点击事件统计的简单实例
2016/07/10 Javascript
Bootstrap导航条可点击和鼠标悬停显示下拉菜单
2016/11/25 Javascript
JS实现的驼峰式和连字符式转换功能分析
2016/12/21 Javascript
Bootstrap实现提示框和弹出框效果
2017/01/11 Javascript
w3c编程挑战_初级脚本算法实战篇
2017/06/23 Javascript
jQuery基于cookie实现换肤功能实例
2017/10/14 jQuery
浅谈Vue.js中ref ($refs)用法举例总结
2017/12/19 Javascript
vue中当图片地址无效的时候,显示默认图片的方法
2018/09/18 Javascript
js实现一个简易计算器
2020/03/30 Javascript
vuex管理状态仓库使用详解
2020/07/29 Javascript
[01:03:47]VP vs NewBee Supermajor 胜者组 BO3 第一场 6.5
2018/06/06 DOTA
Python中is与==判断的区别
2017/03/28 Python
python查看列的唯一值方法
2018/07/17 Python
使用python的turtle函数绘制一个滑稽表情
2020/02/28 Python
如何向scrapy中的spider传递参数的几种方法
2020/11/18 Python
浅析移动设备HTML5页面布局
2015/12/01 HTML / CSS
共产党员公开承诺践诺书
2014/05/28 职场文书
群众路线查摆问题整改措施思想汇报
2014/10/10 职场文书
调解书格式范本
2015/05/20 职场文书
青年教师听课心得体会
2016/01/15 职场文书
24年收藏2000多部退役军用电台
2022/02/18 无线电