IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vue实现登录以及登出 -> 正文阅读

[JavaScript知识库]Vue实现登录以及登出

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

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

? ? ? ? ? ? ? ? 1.登录页面的布局
????????????????2.创建两个Vue.js文件
????????????????3.一个我们来做登录页和注册页
????????????????4.登录页面的布局
????????????????5.配置路由
????????????????6.登录表单的数据绑定
????????????????7.登录表单的验证规则
????????????????8.登录表单的重置
????????????????9.登录预验证
????????????????10.登录组件配置弹窗提示
????????????????11.登录成功后的行为
????????????????12.将登录之后的token,保存到客户端的sessionStorage中
????????????????13.通过编程式导航跳转到后台主页,路由地址是默认路径 '/'
????????????????14.在我们首页的登出,组件配置弹窗提示,把我们的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)

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-09-24 10:26:52  更:2021-09-24 10:26:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/19 0:08:34-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码