Ajax引擎 ajax请求
这篇文章给大家介绍Ajax引擎 ajax请求,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
什么是AJAX引擎?
AJAX引擎其实是一个JavaScript对象,全写是 window.XMLHttpRequest对象,由于浏览器的版本不同,特别是老版本的IE浏览器,虽然也支持AJAX引擎,但是写法上有区别,在IE低版本中通常用 ActiveXObject对象来创建AJAX引擎。 AJAX 来自英文“Asynchronous Javascript And XML” 的缩写,也称为异步JavaScript和XML。 简言之,就是一个JS对象,可以实现在网页加载完成以后,不用刷新的情况下与服务器交互。产生极好的用户体验效果。
AJAX用来做什么?
AJAX技术广泛应用于实现用户体验良好的一个个交互功能,比如:
搜索产品时的关键词推荐
注册新用户的重名提示
现在网站几乎全部都使用Ajax技术,最具有代表使用Ajax技术的网站有:新浪微博、Google地图、百度搜索、淘宝网等等。
AJAX的实现原理
Ajax的原理简单来说通过浏览器的javascript对象XMLHttpRequest(Ajax引擎)对象向服务器发送异步请求并接收服务器的响应数据,然后用javascript来操作DOM而更新页面。这其中最关键的一步就是从服务器获得请求数据。即用户的请求间接通过Ajax引擎发出而不是通过浏览器直接发出,同时Ajax引擎也接收服务器返回响应的数据,所以不会导致浏览器上的页面全部刷新。
AJAX请求步骤详细代码
由于AJAX是一项从客户端发起,和服务器进行交互的技术,所以必须涉及两个方面:客户端和服务器端,下面咱们以会员注册的用户名为例给大家写一个AJAX的详细请求步骤和代码:
客户端代码 reg.html
<!DOCTYPE html><html><head><meta charset="utf-8"/><title>AJAX引擎实现用户名重名检测</title></head><body><form><p>用户名:<input type="text" name="username" id="username"/> <span id="result"></span></p><p>密码:<input type="password" name="pwd1"/></p><p>确认密码:<input type="password" name="pwd2"/></p><p><input type="button" value="立即注册"/></p></form><script type="text/javascript">var username=document.getElementById('username');//用户名输入框失去焦点时触发username.onblur=function(){//主角登场——AJAX引擎的创建及使用详细代码来了var ajax=new XMLHttpRequest(); //创建AJAX引擎实例//创建GET请求,发送请求时传username值ajax.open('GET','check.php?username='+this.value);//当AJAX引擎的状态产生改变时触发onreadystatechange属性指向的函数(多次执行)//状态值有5个:0 1 2 3 4 ,其中4表示服务器端响应就绪ajax.onreadystatechange=function(){//必须在服务器响应就绪,并且HTTP的状态码是200时才接收数据//ajax.readyState 获取到服务器响应状态码,必须是4才表示就绪//ajax.status 获取到HTTP的状态码,必须是200才表示成功if(ajax.readyState==4 && ajax.status==200){//ajax.responseText 接收服务器响应回来的内容//console.log(ajax.responseText);//接收到服务器响应数据后,AJAX工作已完成,可根据结果显示提示信息If(ajax.responseText=='1'){result.innerHTML='该用户名太受欢迎,请重新选择';result.style.color='#f00'; //将字体设置为红色}else{result.innerHTML='恭喜你,可以注册';result.style.color='#0a0'; //将字体设置为绿色}}}ajax.send(); //发送请求}</script></body></html>
服务器端代码 check.php
//服务器端的代码可以使用PHP编写,根据逻辑反馈数据给客户端实现验证功能$username=$_GET['username'];//连接数据库的代码省略$sql="select id from users where username='$username'";$rs=mysqli_query($link,$sql); //将构造好的SQL语句发到服务器上执行if( mysqli_num_rows($rs) ){echo '1'; //如果用户名找到有结果,证明该用户名已存在,返回1}else{echo '0'; //如果用户名未找到结果,证明该用户名不存在,返回0}//关闭数据库连接,释放结果集
==附:AJAX的方法和属性表==
方法:
属性:
关于Ajax引擎 ajax请求就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341