当前位置: 代码网 > it编程>前端脚本>Ajax > AJAX检测用户名是否存在的方法

AJAX检测用户名是否存在的方法

2024年05月18日 Ajax 我要评论
本文实例为大家分享了ajax检测用户名是否存在的具体代码,供大家参考,具体内容如下vscode:index:<!doctype html><html lang="en"><

本文实例为大家分享了ajax检测用户名是否存在的具体代码,供大家参考,具体内容如下

vscode:

index:

<!doctype html>
<html lang="en">
<head>
 <meta charset="utf-8">
 <title>title</title>
</head>
<body>
 <h2>用户注册</h2>
 <form action="/doreg" method="post">
  <ul>
   <li>用户名:<input type="text" name="username" id="user"><span id="msg"></span></li>
   <li>密码:<input type="text" name="pwd"></li>
   <li>确认密码:<input type="text" name="repwd"></li>
   <li><input type="submit" value="注册"></li>
  </ul>
 </form>
 <script>
  let user = document.queryselector("#user")
  let msg = document.queryselector("#msg")
  user.onblur = function(){
   // alert("hello")
   // 第一步:创建一个ajax对象
   let xhr = new xmlhttprequest(); // xhr表示ajax对象 此时ajax的状态是0
   // console.log(xhr.readystate)
   // 第二步:和服务器建立连接 get表示需要把数据放在url中
   xhr.open("get","/check?username="+user.value)// 此时ajax的状态是1
   // console.log(xhr.readystate)
   // 第三步:发出请求
   xhr.send(null); // null表示请求体是空 get请求的请求体都是空 post请求的请求体不空
   // 第四步:得到服务器响应的结果 监听ajax状态变化
   xhr.onreadystatechange = function () { // 当状态发生改变,就会触发onreadystatechange事件
    // console.log(xhr.readystate); // xhr.readystate获取ajax对象的状态
    if(xhr.readystate === 4 && xhr.status == 200){
     // xhr.responsetext 获取服务器响应的数据
     // console.log(xhr.responsetext)
     msg.innerhtml = xhr.responsetext;
    }
   }

  }

 </script>
</body>
</html>

js:

let express = require("express");
let bodyparser = require("body-parser");
let app = express();

// 给ejs模板引擎设置别名,别名叫html
app.engine("html",require("ejs").__express);
app.set("view engine","html");// 使用html模板引擎
// 指定模板的存放位置
app.set("views","./views")

// 配置bodyparser
app.use(bodyparser.json())
app.use(bodyparser.urlencoded({extended:false}))

// 路由
app.get("/",(req,res)=>{
 res.render("reg01"); // 渲染模块
})

// 处理注册
app.post("/doreg",(req,res)=>{
 // 获取客户端传递的数据
 let username = req.body.username.trim();
 let pwd = req.body.pwd.trim();
 let repwd = req.body.repwd.trim();
 // console.log(username,pwd,repwd)

 // 模拟从数据库中获取的用户信息
 let users = ["wangcai","xiaoqiang","admin"];
 if(users.find(user=>user===username)){
  res.send("<h1 style='color: red'>对不起,该用户名已经被注册了,请换个用户名~<a href='/'>返回注册页</a></h1>")
 }else{
  res.send("<h1 style='color: green'>恭喜你,该用户名可以使用~<a href='/'>返回注册页</a></h1>")
 }
})

app.listen(3000,()=>{
 console.log("server is running on 3000~")
})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com