yunzer/app/index/view/user/register.php
2025-05-26 23:54:51 +08:00

240 lines
8.1 KiB
PHP

<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" href="__LAYUI__/css/layui.css">
<script src="__LAYUI__/layui.js" charset="utf-8"></script>
<title>用户注册</title>
<style>
/* 保持原有样式不变 */
body {
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
background: #f5f7fa;
display: flex;
justify-content: center;
align-items: center;
min-height: 100vh;
margin: 0;
padding: 20px;
}
.register-container {
width: 420px;
background: #fff;
border-radius: 12px;
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.05);
overflow: hidden;
}
.register-header {
padding: 40px 40px 20px;
text-align: center;
}
.register-header h2 {
font-size: 28px;
color: #333;
margin: 0;
font-weight: 600;
}
.register-header p {
color: #666;
margin: 10px 0 0;
font-size: 15px;
}
.register-form {
padding: 20px 40px 40px;
}
.layui-form-item {
margin-bottom: 25px;
}
.layui-input {
height: 45px;
line-height: 45px;
border-radius: 8px;
border: 1px solid #e4e7ed;
padding: 0 15px;
transition: all 0.3s;
}
.layui-input:focus {
border-color: #409eff;
box-shadow: 0 0 0 2px rgba(64, 158, 255, 0.1);
}
.layui-btn {
height: 45px;
line-height: 45px;
border-radius: 8px;
font-size: 16px;
background: #409eff;
transition: all 0.3s;
}
.layui-btn:hover {
background: #66b1ff;
transform: translateY(-1px);
}
.layui-input-inline {
margin-right: 0px !important;
}
#getCode {
height: 45px;
line-height: 45px;
padding: 0 20px;
font-size: 14px;
}
.layui-input-block {
display: flex;
justify-content: space-between;
}
.login-link {
text-align: center;
margin-top: 20px;
color: #666;
}
.login-link a {
color: #409eff;
text-decoration: none;
}
.login-link a:hover {
text-decoration: underline;
}
</style>
</head>
<body>
<div class="register-container">
<div class="register-header">
<h2>用户注册</h2>
<p>创建您的账号</p>
</div>
<form action="#" method="post" class="layui-form register-form">
<div class="layui-form-item">
<div class="layui-input-block" style="margin-left: 0;">
<input type="account" name="account" required lay-verify="required|account" placeholder="请输入邮箱"
autocomplete="off" class="layui-input">
</div>
</div>
<div class="layui-form-item">
<div class="layui-input-block" style="margin-left: 0;">
<div class="layui-input-inline" style="width: calc(100% - 120px);">
<input type="text" name="code" required lay-verify="required" placeholder="请输入验证码"
autocomplete="off" class="layui-input">
</div>
<div class="layui-input-inline" style="width: 110px;">
<button type="button" class="layui-btn" id="getCode">获取验证码</button>
</div>
</div>
</div>
<div class="layui-form-item">
<div class="layui-input-block" style="margin-left: 0;">
<input type="password" name="password" required lay-verify="required" placeholder="请输入密码"
autocomplete="off" class="layui-input">
</div>
</div>
<div class="layui-form-item">
<div class="layui-input-block" style="margin-left: 0;">
<input type="password" name="repassword" required lay-verify="required" placeholder="请确认密码"
autocomplete="off" class="layui-input">
</div>
</div>
<div class="layui-form-item">
<div class="layui-input-block" style="margin-left: 0;">
<button class="layui-btn layui-btn-fluid" lay-submit lay-filter="register">注册</button>
</div>
</div>
<div class="login-link">
已有账号?<a href="{:url('/index/user/login')}">立即登录</a>
</div>
</form>
</div>
<script>
layui.use(['form', 'layer'], function () {
var form = layui.form;
var layer = layui.layer;
var $ = layui.$;
// 注册表单提交
form.on('submit(register)', function (data) {
$.ajax({
url: '{:url("index/user/register")}',
type: 'POST',
data: data.field,
success: function (res) {
if (res.code === 0) {
layer.msg('注册成功', {
icon: 1,
time: 1000
}, function () {
window.location.href = '{:url("index/user/login")}';
});
} else {
layer.msg(res.msg);
}
},
error: function () {
layer.msg('网络错误,请稍后重试');
}
});
return false;
});
// 获取验证码按钮点击事件
document.getElementById('getCode').addEventListener('click', function () {
var account = document.querySelector('input[name="account"]').value;
if (!account) {
layer.msg('请先输入邮箱地址');
return;
}
// 发送邮箱验证码请求
$.ajax({
url: '{:url("index/user/sendEmailCode")}',
type: 'POST',
data: { account: account },
dataType: 'json', // 添加这行
success: function (res) {
if (res.code === 0) {
layer.msg('验证码已发送,请查收邮件');
// 禁用按钮60秒
var btn = document.getElementById('getCode');
var countdown = 60;
btn.disabled = true;
var timer = setInterval(function () {
if (countdown > 0) {
btn.innerHTML = countdown + '秒后重试';
countdown--;
} else {
btn.disabled = false;
btn.innerHTML = '获取验证码';
clearInterval(timer);
}
}, 1000);
} else {
layer.msg(res.msg);
}
},
error: function (xhr, status, error) {
console.log(xhr.responseText); // 添加调试信息
layer.msg('网络错误,请稍后重试');
}
});
});
});
</script>
</body>
</html>