AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。 通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。 传统的网页(不使用 AJAX)如果需要更新内容,必须重载整个网页页面 使用Javascript向服务器提出请求并处理响应而不阻塞用户!核心对象XMLHTTPRequest。通过这个对象,您的 JavaScript 可在不重载页面的情况与Web服务器交换数据。什么是readyState readyState是XMLHttpRequest对象的一个属性,用来标识当前XMLHttpRequest对象处于什么状态。 readyState总共有5个状态值,分别为0~4,每个值代表了不同的含义,如下表所示: 0 未初始化状态:此时,已经创建了一个XMLHttpRequest对象 1 准备发送状态:此时,已经调用了XMLHttpRequest对象的open方法,并且XMLHttpRequest对象已经准备好将一个请求发送到服务器端 2 已经发送状态:此时,已经通过send方法把一个请求发送到服务器端,但是还没有收到一个响应 3 正在接收状态:此时,已经接收到HTTP响应头部信息,但是消息体部分还没有完全接收到 4 完成响应状态:此时,已经完成了HTTP响应的接收什么是status status是XMLHttpRequest对象的一个属性,表示响应的HTTP状态码。 在HTTP1.1协议下,HTTP状态码总共可分为5大类,如下表所示: 1XX 服务器收到请求,需要继续处理。例如101状态码,表示服务器将通知客户端使用更高版本的HTTP协议。 2XX 请求成功。例如200状态码,表示请求所希望的响应头或数据体将随此响应返回。 3XX 重定向。例如302状态码,表示临时重定向,请求将包含一个新的URL地址,客户端将对新的地址进行GET请求。 4XX 客户端错误。例如404状态码,表示客户端请求的资源不存在。 5XX 服务器错误。例如500状态码,表示服务器遇到了一个未曾预料的情况,导致了它无法完成响应,一般来说,这个问题会在程序代码出错时出现。//xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");实例: //创建对象 if(window.XMLHttpRequest){ //创建非IE的http对象 httpObj = new XMLHttpRequest(); }else{ //创建ie低版本的http对象 httpObj = new ActiveXObject('Microsoft.XMLHTTP'); } //连接服务器,并发送数据 httpObj.open('get','http://localhost/p30/my_project/index.PHP?userName='+encodeURIComponent(userName)+'&pwd='+encodeURIComponent(pwd),true); ***如果该请求方式为post请求,则需要对请求头进行设置 httpObj.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); //发送数据get方式发送数据如下 httpObj.send(null); ***如果请求方式为post方式 则该null修改为要发送的数据格式为 name=value&name1=value2,即 httpObj.send('name=value&name1=value2'); //返回响应 httpObj.onreadystatechange = function(){ alert(httpObj.readyState); if(httpObj.readyState == 4){ if(httpObj.status == 200){ var result = httpObj.responseText; document.write(result); /* for(var a in result){ alert(result.a); }*/ } }else{ alert('请求错误'); } };
原文链接:https://www.f2er.com/ajax/161949.html