千家信息网

如何使用Ajax实时检测"用户名、邮箱等"是否已经存在

发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,本篇内容主要讲解"如何使用Ajax实时检测"用户名、邮箱等"是否已经存在",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"如何使用Ajax实时检测"用户名、邮
千家信息网最后更新 2025年01月19日如何使用Ajax实时检测"用户名、邮箱等"是否已经存在

本篇内容主要讲解"如何使用Ajax实时检测"用户名、邮箱等"是否已经存在",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"如何使用Ajax实时检测"用户名、邮箱等"是否已经存在"吧!

利用Ajax技术来检测用户名是否存在的原理流程图:

最终结果截图:

复制代码 代码如下:






Ajax检测用户名




用户名:





代码解释:

①实现该功能的核心代码在ajax.js,需要另外引进

②给form命名,因为后面我们需要利用JS来取得input框中的value

③给input框添加一个"onblur"事件,即当"焦点"失去时触发该事件(即流程图的"触发控件")

用来放从服务器发送回来的数据(即"用户名已存在"等)

复制代码 代码如下:


mysql_connect("localhost",'root','');
mysql_select_db('test');
$sql="select * from ajax where name='$_GET[id]'";
$query=mysql_query($sql);
if(is_array(mysql_fetch_array($query))){
echo "用户名已存在";
}else{
echo "用户名可以使用";
}
?>

代码解释:

通过ajax的open方法,将用户输入"用户名"通过id传递给进来(即$_GET[id]),此时将对指定的数据库表中进行查询,检查是否有存在该"用户名"

复制代码 代码如下:


// JavaScript Document
var XHR; //定义一个全局对象
function createXHR(){ //首先我们得创建一个XMLHttpRequest对象
if(window.ActiveXObject){//IE的低版本系类
XHR=new ActiveXObject('Microsoft.XMLHTTP');//之前IE垄断了整个浏览器市场,没遵循W3C标准,所以就有了这句代码。。。但IE6之后开始有所改观
}else if(window.XMLHttpRequest){//非IE系列的浏览器,但包括IE7 IE8
XHR=new XMLHttpRequest();
}
}
function checkname(){
var username=document.myform.user.value;
createXHR();
XHR.open("GET","checkname.php?id="+username,true);//true:表示异步传输,而不等send()方法返回结果,这正是ajax的核心思想
XHR.onreadystatechange=byhongfei;//当状态改变时,调用byhongfei这个方法,方法的内容我们另外定义
XHR.send(null);
}
function byhongfei(){
if(XHR.readyState == 4){//关于Ajax引擎对象中的方法和属性,可以参考下面文章:https://www.jb51.net/article/29012.htm
if(XHR.status == 200){
var textHTML=XHR.responseText;
document.getElementById('checkbox')[xss_clean]=textHTML;
}
}
}


代码解释:

①首先我们需要声明一个ajax引擎的对象:XHR(随便命名一个)

②因为微软的低版本IE和其他的浏览器创建ajax对象的方式不一样,现在IE和其他浏览器的市场份额几乎各占一半,所以我们得两方面都考虑到,IE-->ActiveXObject;其他-->XMLHttpRequest。我将她封装在一个函数中:createXHR

③我们在index.html中指定的当失去"焦点"时就会触发checkname()函数。那么我们如何将用户输入的"用户名"捕获呢?这里,利用js即可轻松捕获到document.myform.user.value(现在知道为何给form和input命名了吧,这一步对应流程图的"获得填写内容"),有兴趣的博友,可以试试在createXHR()的前一行敲行代码(alert(username)),将捕获到的用户名弹出试试看。

④Ajax引擎有几个方法和属性(可以参考我的另一篇博文:看图理解:普通交互方式和Ajax交互方式区别),使用之前我们得先调用函数craateXHR创建一个ajax对象

⑤有了ajax对象,有三个方法是必不可少的:open()、onreadystatechange、send()。

将请求发送到服务器,要使用open ()和send()方法
open()方法的第一个参数,指示采用GET或者POST方式进行传输。。。。。。
open()方法的第二个参数,指示要请求的URL地址(这里我们请求的是checkname.php文件),可以是绝对或相对地址
open()方法的第三个参数async指示是否采用异步请求,true为采用,这种情况下,通过ajax、js无需等待服务器响应,而是:①在等待服务器响应的同时执行其他脚本②当响应就绪后对响应进行处理。一般对一些小型的请求,async=false也是可以的,但此时就不要编写onreadystatechange 函数了
onreadystatechange事件:当ajax的属性readyState改变时,就触发此事件。在此事件中,当服务器响应已做好被处理的准备时(即readyState=4且status=200时),我们规定要让服务器做什么任务,这里我们规定将从数据库检索到的结果输出到id为"checkbox"的span标签中。
⑥通过checkname.php,查询数据库后,将得到查询结果(即服务器的响应,对应流程图中的"查询数据库"),此时数据还在ajax引擎中,如需获得该来自服务器的响应,我们需要使用XMLHttpRequest对象的responText或responseXML属性,并通过DOM属性innerHTML将从服务器响应回来的数据设置为id="checkbox"的span标签的值

注:利用ajax监测邮箱是否存在一个道理,我们还可以利用ajax实时监测用户输入的密码强度,此时,需要用到可以把onblur事件改为onfocus事件。

到此,相信大家对"如何使用Ajax实时检测"用户名、邮箱等"是否已经存在"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

用户 用户名 代码 方法 服务器 服务 对象 事件 数据 检测 属性 查询 实时 邮箱 内容 函数 引擎 数据库 方式 流程 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 社会发展推动网络技术革新 sql数据库开放端口 用于服务器工作站的主板类型 前台收银管理与服务器 vb 数据库编程教程讲解 安卓软件开发学费 增城服务器运维服务找哪家 bim软件开发工程基础知识 方舟生存进化手游灵异服务器 海康威视修改服务器提示参数错误 济南云畅网络技术怎么样 勤哲excel服务器知名度 我的世界服务器怎么删除玩家信息 金龄科技老年互联网 车载网络技术的好处有哪些 未来科技网络技术 郴州电子软件开发培训学校 网上改造服务器 数据库角色和用户有什么区别 常见数据库中索引使用的数据结构 数据库简单操作实验报告原理 英文数据库有哪几种 随着科技的发展互联网的 内网穿透必须要公网服务器吗 网络安全宣传周如何应对 鸠鸠互联网科技乔迁 此服务器处于离线状态 如何用vb创建mdb数据库 数据库下载32位下载地址 因数据库属于回避恢复
0