Vue实现登录以及登出详解

 更新时间:2021年09月24日 11:02:45   作者:难过的新手村  
本篇文章主要介绍了vue实现登陆登出的实现示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

首先先了解一下,我们的效果实现流程

首先登录概述及业务流程和相关技术点

  • 录页面的布局
  • 创建两个Vue.js文件
  • 一个我们来做登录页和注册页
  • 登录页面的布局
  • 配置路由
  • 登录表单的数据绑定
  • 登录表单的验证规则
  • 登录表单的重置
  • 登录预验证
  • 登录组件配置弹窗提示
  • 登录成功后的行为
  • 将登录之后的token,保存到客户端的sessionStorage中
  • 通过编程式导航跳转到后台主页,路由地址是默认路径 '/'
  • 在我们首页的登出,组件配置弹窗提示,把我们的token使用removeItem删除

登录业务流程

1.在登录页面输入用户名和密码

2.调用后台接口进行验证

3.通过验证之后,根据后台得响应状态跳转到项目主页

登录功能实现

1.首先我们用路由守卫来验证登录,判断是否与需要登录

{
    path:'/login',
    name:"login",
    component:login,
    meta:{
      login:true
    }
} 
  // 需要登录的地方定义meta-true  看他需不需要登录
   if(to.matched.some(item=>item.meta.login)){//需要登录
    console.log("需要登录");
    if(isLogin){//1.已经登录,直接通过
        if(data.error===400){//后端告诉你,登录不成功
            next({name:'login'})
            localStorage.removeItem('token');
            return;
        }
        if(to.name==='login'){
            next({name:'Home'})
        }else{
            next()
        }
        return;
    }
    if(!isLogin && to.name==='login'){//2.未登录,但要去登录页
        next()
    }
    if(!isLogin && to.name !=='login'){//3.未登录,去的也不是登录页
        next({name:"login"})
    }
   }else{//不需要登录直接进
       next()
   }           

2.表单的验证规则,我们用的是Element的组件库

在模板中用Element编写我们的样式布局

 <div class="login-section">
    <!-- :rules="rules" -->
    <el-form
      label-position="top"
      label-width="100px" class="demo-ruleForm"
      :rules="rules"
      :model="rulesFrom"
      status-icon
      ref="ruleFrom"
    >
      <el-form-item label="用户名" prop="name">
        <!--             使用v-model来获取用户输入的名字                    -->
        <el-input type="text" v-model="rulesFrom.name"></el-input>
      </el-form-item>
      <el-form-item label="密码" prop="password"></el-form-item>
        <!--             使用v-model来获取用户输入的密码                    -->
        <el-input type="password" v-model="rulesFrom.password"></el-input>
      </el-form-item>
      <el-form-item>
        <!--                    定义提交事件             -->
        <el-button type="primary" @click="submitFrom('ruleFrom')">提交</el-button>
        <el-button>重置</el-button>
      </el-form-item>
    </el-form>
  </div>

定义表单的验证规则

详细的看Element官网from表单

在Data里面定义

rulesFrom:{
        name:'',
        password:''
      },
      rules:{
        name:[
          // 验证规则
          {required:true,message:'请输入用户名',trigger:'blur'},
          {min:1,max:5,message:'长度在1到5个字符',trigger:'blur'}
        ],
        password:[
          {required:true,message:'请输入密码',trigger:'blur'},
          {min:1,max:5,message:'长度在1到5个字符',trigger:'blur'}
        ]
      }

在methods定义提交事件

 // 当我们点击提交的时候能出发方法能拿到表单的所有东西
    submitFrom(formName){
      this.$refs[formName].validate( (valid)=>{
        if(valid){
          // 如果校检通过,再里向后端返送用户信息和密码
          login({
            name:this.rulesFrom.name,
            password:this.rulesFrom.password,
          }).then((data)=>{
            console.log(data);
            if(data.code===0){
              localStorage.setItem('token',data.data.token)
              window.location.href='/';
            }
            if(data.code===1){
              this.$message.error(data.mes)
            }
          })
        }else{
          console.log('error submit!!');
          return false
        }
      })
    }

这个时候把登出也写一下在router beforeEach中给他转换

const token=localStorage.getItem('token');
//    !!token转换成布尔类型
   const isLogin=!!token;
//    进入路由的时候,需要向后端返送token,验证是否合法
    const data=await userInfo();
    Store.commit('chageUserInfo',data.data)

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

相关文章

  • VueUse功能精简你的dependencies

    VueUse功能精简你的dependencies

    这篇文章主要为大家介绍了VueUse功能精简你的dependencies实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • vue3父组件和子组件如何传值实例详解

    vue3父组件和子组件如何传值实例详解

    近期学习vue3的父子组件之间的传值,发现跟vue2.x的父子组件之间的传值并没有太大的区别,下面这篇文章主要给大家介绍了关于vue3父组件和子组件如何传值的相关资料,需要的朋友可以参考下
    2022-08-08
  • vue-cli构建项目下使用微信分享功能

    vue-cli构建项目下使用微信分享功能

    这篇文章主要介绍了vue-cli构建项目下使用微信分享功能,本文通过实例代码相结合的形式给大家介绍的非常详细,感兴趣的朋友跟随脚本之家小编一起学习吧
    2018-05-05
  • Element-ui之ElScrollBar组件滚动条的使用方法

    Element-ui之ElScrollBar组件滚动条的使用方法

    这篇文章主要介绍了Element-ui之ElScrollBar组件滚动条的使用方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • vue设置全局访问接口API地址操作

    vue设置全局访问接口API地址操作

    这篇文章主要介绍了vue设置全局访问接口API地址操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • element中使用formdata进行上传文件的方法

    element中使用formdata进行上传文件的方法

    本文主要介绍了elementUI中使用formdata进行上传文件的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • Vue中的ESLint配置方式

    Vue中的ESLint配置方式

    这篇文章主要介绍了Vue中的ESLint配置方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • Vue概念及常见命令介绍(1)

    Vue概念及常见命令介绍(1)

    这篇文章主要为大家详细介绍了Vue概念及常见命令,介绍了vue.js声明式渲染、双向绑定及常用指令,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • Vue+Canvas制作简易的水印添加器小工具

    Vue+Canvas制作简易的水印添加器小工具

    随着搬运工的逐渐增加,原创作者的利益收到了极大的影响。所以给图片或视频加上水印显得极其重要。本文分享一个由canvas和vue.js制作的图片水印添加器,需要的可参考一下
    2022-06-06
  • 35个最好用的Vue开源库(史上最全)

    35个最好用的Vue开源库(史上最全)

    无论是开发新手还是经验丰富的老手,我们都喜欢开源软件包。本文主要介绍了35个最好用的Vue开源库,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01

最新评论