有关Ajax引擎 ajax请求步骤详细代码方案

什么是AJAX引擎?

AJAX引擎实际上是JavaScript对象,全部是window .作为XMLHttpRequest对象创建。由于浏览器版本不同,尤其是早期版本的IE浏览器也支持AJAX引擎,但在标记上存在差异,因此IE之前版本中常用的ActiveXObject对象AJAX是英语“Asynchronous JavaScript And XML”的缩写,也称为异步JavaScript和XML。简而言之,这是一个JS对象,网页加载完成后,无需刷新即可与服务器交互。提供优秀的用户体验。

AJAX用来做什么?

AJAX技术广泛应用于实现用户体验良好的一个个交互功能,比如:

2018101584632492

搜索产品时的关键词推荐

2018101584649272

注册新用户的重名提示

现在网站几乎全部都使用Ajax技术,最具有代表使用Ajax技术的网站有:新浪微博、Google地图、百度搜索、淘宝网等等。

AJAX的实现原理

Ajax的原理简单来说就是通过浏览器的JavaScript对象XMLHttpRequest(Ajax引擎)对象向服务器发送异步请求,接收服务器的响应数据,然后使用JavaScript操作最重要的步骤是从服务器获取请求的数据。也就是说,用户的请求是通过Ajax引擎间接发送的,而不是通过浏览器发送的,Ajax引擎接收服务器返回响应的数据,因此不会刷新浏览器中的所有页面。

2018101584703465

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的方法和属性表==

方法:

201810150836034

属性:

201810150836035

最后,注意一个重要的问题,XMLHttpRequest对象是没有跨域能力的,也就是说 ajax不能请求获得其它网站的数据,那有没有解决办法呢? 答案是肯定的,需要使用JSONP

© 版权声明
THE END
喜欢就支持一下吧
点赞11 分享
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码图片