Element-UI登录页面案例分享(Demo)
【辰兮要努力】:hello你好我是辰兮,很高兴你能来阅读,昵称是希望自己能不断精进,向着优秀程序员前行!博客来源于项目以及编程中遇到的问题总结,偶尔会有读书分享,我会陆续更新Java前端、后台、数据库、项目案例等相关知识点总结,感谢你的阅读和关注,希望我的博客能帮助到更多的人,分享获取新知,大家一起进步!吾等采石之人,应怀大教堂之心,愿你们奔赴在各自的热爱中…最近打算系统的整理一下一个vue +
·
【辰兮要努力】:hello你好我是辰兮,很高兴你能来阅读,昵称是希望自己能不断精进,向着优秀程序员前行!
博客来源于项目以及编程中遇到的问题总结,偶尔会有读书分享,我会陆续更新Java前端、后台、数据库、项目案例等相关知识点总结,感谢你的阅读和关注,希望我的博客能帮助到更多的人,分享获取新知,大家一起进步!
吾等采石之人,应怀大教堂之心,愿你们奔赴在各自的热爱中…
最近打算系统的整理一下一个vue + element-ui框架的简单应用。分模块整理一下demo,以及部分基础知识,分享给初学者,同时自己也多反思学习。
简单的分享一个登录vue + element-ui逻辑
注意事项:
1、正则表达式的相关校验(电话号码,邮箱登录校验等等)
2、登录 如果成功路由跳转到下一个页面 如果失败弹出提示
相关页面的详情,我在如下代码写了很详细的备注,一起学习,共同进步
<template>
<div class="login_container">
<div class="login_box">
<!-- 头像 -->
<div class="avatar_box">
<img src="../assets/logo.png" alt="">
</div>
<!-- 表单 -->
<el-form ref="LoginFormRef" :model="loginForm" label-width="0" :rules="LoginFormRules" class="login_form">
<el-form-item prop="username">
<!-- 用户名-->
<el-input v-model="loginForm.username" prefix-icon="el-icon-user"></el-input>
</el-form-item>
<!-- 密码-->
<el-form-item prop="password">
<el-input v-model="loginForm.password" prefix-icon="el-icon-lock" type="password"></el-input>
</el-form-item>
<el-form-item class="btns">
<el-button type="primary" @click="login">登录</el-button>
<el-button type="info" @click="resetLoginForm">重置</el-button>
</el-form-item>
</el-form>
</div>
</div>
</template>
<script>
export default {
data() {
return {
// 登录的初始化数据:备注默认应该是空
loginForm:{
username:'',
password:''
},
// 正则表达式的相关校验
LoginFormRules:{
username:[
{ required: true, message: '请输入用户名', trigger: 'blur' },
],
password:[
{ required: true, message: '请输入密码', trigger: 'blur' },
]
}
}
},
methods: {
// 清空表单的校验
resetLoginForm() {
this.$refs.LoginFormRef.resetFields()
},
//登录的方法:登录逻辑写里面
login() {
//首先是校验如果正则的校验通过 -->> 执行数据传输
this.$refs['LoginFormRef'].validate(async (valid) => {
if (valid) {
//简单的在main.js里面配置了一下如下
//Vue.prototype.$http = axios
//axios.defaults.baseURL = 'https://localhost:8080/api/private/v1/'
//执行数据的交互过程 --即对服务端对应接口进行访问
const {data:res} = await this.$http.post('login',this.loginForm)
//正常这里是要分情况写: 1.如果成功 登录到首页面 2.如果失败 弹出对应的提示
if (res.meta.status==200){
this.$message({
message:'登录成功',
type:'success'
})
//如果登录成功存储token
window.sessionStorage.setItem('token',res.data.token)
//跳到首页面 这里是根据路由跳转
this.$router.push('/home')
}else{
this.$message({
message:res.meta.msg,
type:'error'
})
}
} else {
return false
}
})
}
}
}
</script>
<style lang="less" scoped>
.login_container{
background-color: #2b4b6b;
height: 100%;
}
.login_box{
width: 450px;
height: 300px;
background-color: #fff;
border-radius: 3px;
position: absolute;
left: 50%;
top: 50%;
transform: translate(-50%,-50%)
}
.avatar_box{
width: 130px;
height: 130px;
border: 1px solid #eee;
border-radius: 50%;
padding: 10px;
box-shadow: 0 0 10px #ddd;
position: absolute;
left:50%;
transform: translate(-50%,-50%);
background-color: #fff;
img{
width: 100%;
height: 100%;
border-radius: 50%;
background-color: #eee;
}
}
.login_form{
position: absolute;
bottom: 0;
width: 100%;
padding: 20px;
box-sizing: border-box;
}
.btns{
display: flex;
justify-content:flex-end;
}
</style>>
下期Element-UI案例见!
非常感谢你阅读到这里,如果这篇文章对你有帮助,希望能留下你的点赞👍 关注❤️ 分享👥 留言💬thanks!!!
2021年2月27日21:54:31 愿你们奔赴在自己的热爱里!
更多推荐
已为社区贡献9条内容
所有评论(0)