在给定的register.html页面代码的基础上,完成新账号的注册过程 (1)输入账号离开User_name文本框时,使用Ajax对账号进行查重操作,若账号重复,则弹出消息框显示提示信息
时间: 2024-03-26 07:41:40 浏览: 69
好的,我来帮你解决这个问题。首先,你需要在前端代码中添加一个事件监听器,当用户输入完账号后离开User_name文本框时,触发Ajax请求,向后端发送查询账号是否重复的请求。以下是代码示例。
```html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Register</title>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<script>
$(document).ready(function(){
$("#User_name").blur(function(){
var username = $(this).val(); // 获取用户输入的账号
$.ajax({
url: "/check_username",
type: "POST",
data: {username: username},
success: function(data){
if(data == "exist"){ // 如果账号已存在
alert("该账号已被注册,请更换账号!");
}
}
});
});
});
</script>
</head>
<body>
<form action="/register" method="POST">
<label for="User_name">账号:</label>
<input type="text" id="User_name" name="username"><br><br>
<label for="Password">密码:</label>
<input type="password" id="Password" name="password"><br><br>
<button type="submit">注册</button>
</form>
</body>
</html>
```
在上述代码中,我们使用了jQuery库来简化Ajax请求的操作,当用户离开User_name文本框时,触发blur事件,获取用户输入的账号,并使用Ajax向后端发送POST请求,请求的URL为/check_username。在后端代码中,我们需要实现一个/check_username的路由,用于处理Ajax请求,查询账号是否重复。
下面是后端代码的示例。
```python
from flask import Flask, request
app = Flask(__name__)
usernames = set() # 用集合保存已注册的账号
@app.route('/check_username', methods=['POST'])
def check_username():
username = request.form['username']
if username in usernames:
return "exist" # 如果账号已存在,返回字符串"exist",在前端代码中进行判断
else:
return "not exist"
@app.route('/register', methods=['POST'])
def register():
username = request.form['username']
password = request.form['password']
# 在这里添加注册用户的代码
usernames.add(username) # 添加已注册的账号
return "register success"
if __name__ == '__main__':
app.run()
```
在上述代码中,我们定义了一个集合usernames,用于保存已注册的账号。当用户提交注册表单时,后端接收到POST请求,获取账号和密码后,进行用户注册,并将已注册的账号添加到usernames集合中。在/check_username路由中,我们查询usernames集合,如果账号已存在,返回字符串"exist",否则返回字符串"not exist"。在前端代码中,当Ajax请求成功后,如果返回的字符串是"exist",则弹出提示框,提示用户更换账号。
希望这个示例能帮到你完成新账号的注册过程。
阅读全文