Vue实现登录以及登出详解
作者:难过的新手村 时间:2023-07-02 16:59:51
首先先了解一下,我们的效果实现流程
首先登录概述及业务流程和相关技术点
录页面的布局
创建两个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)
来源:https://blog.csdn.net/weixin_57259948/article/details/120439822
标签:Vue,登陆
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
anconda的pip下载包出现的问题解决
2022-06-21 22:17:33
![](https://img.aspxhome.com/file/2023/5/131285_0s.jpg)
python numpy实现文件存取的示例代码
2022-01-11 07:14:58
![](https://img.aspxhome.com/file/2023/0/121030_0s.png)
纯手工打造CSS像素画
2009-03-09 12:57:00
![](https://img.aspxhome.com/file/UploadPic/20093/9/01-12s.gif)
windows下安装Python虚拟环境virtualenvwrapper-win
2023-12-23 11:24:08
python性能测试手机号验证码登录压测示例详解
2021-06-05 13:21:25
JavaScript遍历求解数独问题的主要思路小结
2023-10-13 16:41:14
PyTorch搭建CNN实现风速预测
2022-09-11 17:40:19
![](https://img.aspxhome.com/file/2023/8/102328_0s.jpg)
Vue+Element自定义纵向表格表头教程
2023-07-02 17:10:38
![](https://img.aspxhome.com/file/2023/2/139962_0s.jpg)
Tensorflow: 从checkpoint文件中读取tensor方式
2022-07-20 11:39:29
树莓派(python)与arduino串口通信的详细步骤
2022-05-29 15:31:06
![](https://img.aspxhome.com/file/2023/2/109982_0s.png)
CSS 的优先规则
2009-01-08 12:40:00
python实战之百度智能云使人像动漫化
2021-01-19 07:15:11
![](https://img.aspxhome.com/file/2023/9/84869_0s.png)
Pandas替换及部分替换(replace)实现流程详解
2023-11-04 02:58:38
![](https://img.aspxhome.com/file/2023/9/125179_0s.png)
sklearn的predict_proba使用说明
2023-10-24 11:22:08
![](https://img.aspxhome.com/file/2023/9/105329_0s.jpg)
手把手带你了解Python数据分析--matplotlib
2022-05-21 22:07:18
![](https://img.aspxhome.com/file/2023/4/87654_0s.png)
MySQL性能诊断与调优工具
2010-11-02 11:41:00
python 实现在Excel末尾增加新行
2023-11-26 09:27:52
python3实现飞机大战
2023-03-03 00:36:18
![](https://img.aspxhome.com/file/2023/8/87588_0s.jpg)
MySQL获取当前时间的多种方式总结
2024-01-21 02:29:34
![](https://img.aspxhome.com/file/2023/5/79035_0s.png)
保护MySQL数据库中重要数据的注意事项
2009-01-19 11:55:00