作者介绍:
本人Java特工,代号:Cris Li ; 中文名:克瑞斯理
简书地址: https://www.jianshu.com/u/c508b0afaaee
CSDN地址: https://blog.csdn.net/jianli95
个人纯洁版博客: https://lijian69.github.io/blog/
最终的项目图,如图所示:
这里只是附加代码和功能;具体需要有一些基础Vue基础的人
一、表单相关的实现
这里采用的是Element组件,为我们方便进行开发
主要设计到的功能如下:
表单的提交和校验、表单的自定义校验,如下如密码的自定义校验,把文件放在自定义模板组件中
<template>
<div class="page-register">
<article class="header">
<header>
<a href="/" class="site-logo" />
<span class="login">
<em class="bold">已有美团账号?</em>
<a href="/login">
<el-button type="primary" size="small">登录</el-button>
</a>
</span>
</header>
</article>
<section>
<el-form
ref="ruleForm"
:model="ruleForm"
:rules="rules"
label-width="100px"
class="demo-ruleForm"
>
<el-form-item label="昵称" prop="name">
<el-input v-model="ruleForm.name" />
</el-form-item>
<el-form-item label="邮箱" prop="email">
<el-input v-model="ruleForm.email" />
<el-button size="mini" round @click="sendMsg">发送验证码</el-button>
<span class="status">{{ statusMsg }}</span>
</el-form-item>
<el-form-item label="验证码" prop="code">
<el-input v-model="ruleForm.code" maxlength="4" />
</el-form-item>
<el-form-item label="密码" prop="pwd">
<el-input v-model="ruleForm.pwd" type="password" />
</el-form-item>
<el-form-item label="确认密码" prop="cpwd">
<el-input v-model="ruleForm.cpwd" type="password" />
</el-form-item>
<el-form-item>
<el-button type="primary" @click="register">同意以下协议并注册</el-button>
<div class="error">{{ error }}</div>
</el-form-item>
<el-form-item>
<a class="f1" href="http://www.meituan.com/about/terms" target="_blank">《美团网用户协议》</a>
</el-form-item>
</el-form>
</section>
</div>
</template>
<script>
import CryptoJS from "crypto-js";
export default {
data() {
return {
statusMsg: "",
error: "",
ruleForm: {
name: "",
code: "",
pwd: "",
cpwd: "",
email: ""
},
rules: {
name: [
{
required: true,
type: "string",
message: "请输入昵称",
// 失去焦点时候触发检验
trigger: "blur"
}
],
email: [
{
required: true,
type: "email",
message: "请输入邮箱",
trigger: "blur"
}
],
pwd: [
{
required: true,
message: "创建密码",
trigger: "blur"
}
],
cpwd: [
{
required: true,
message: "确认密码",
trigger: "blur"
},
{
validator: (rule, value, callback) => {
if (value === "") {
callback(new Error("请再次输入密码"));
} else if (value !== this.ruleForm.pwd) {
callback(new Error("两次输入密码不一致"));
} else {
callback();
}
},
trigger: "blur"
}
]
}
};
},
layout: "blank",
methods: {
sendMsg: function() {
const self = this;
let namePass;
let emailPass;
if (self.timerid) {
return false;
}
this.$refs["ruleForm"].validateField("name", valid => {
namePass = valid;
});
self.statusMsg = "";
if (namePass) {
return false;
}
this.$refs["ruleForm"].validateField("email", valid => {
emailPass = valid;
});
if (!namePass && !emailPass) {
self.$axios
.post("/users/verify", {
username: encodeURIComponent(self.ruleForm.name),
email: self.ruleForm.email
})
.then(({ status, data }) => {
if (status === 200 && data && data.code === 0) {
let count = 60;
self.statusMsg = `验证码已发送,剩余${count--}秒`;
self.timerid = setInterval(function() {
self.statusMsg = `验证码已发送,剩余${count--}秒`;
if (count === 0) {
clearInterval(self.timerid);
}
}, 1000);
} else {
self.statusMsg = data.msg;
}
});
}
},
register: function() {
let self = this;
this.$refs["ruleForm"].validate(valid => {
if (valid) {
self.$axios
.post("/users/signup", {
username: window.encodeURIComponent(self.ruleForm.name),
password: CryptoJS.MD5(self.ruleForm.pwd).toString(),
email: self.ruleForm.email,
code: self.ruleForm.code
})
.then(({ status, data }) => {
if (status === 200) {
if (data && data.code === 0) {
location.href = "/login";
} else {
self.error = data.msg;
}
} else {
self.error = `服务器出错,错误码:${status}`;
}
setTimeout(function() {
self.error = "";
}, 1500);
});
}
});
}
}
};
</script>
<style lang="scss">
@import "@/assets/css/register/index.scss";
</style>