四步輕松實(shí)現(xiàn)ajax發(fā)送異步請(qǐng)求
ajax發(fā)送異步請(qǐng)求,供大家參考,具體內(nèi)容如下
第一步(得到XMLHttpRequest)
ajax其實(shí)只需要學(xué)習(xí)一個(gè)對(duì)象:XMLHttpRequest,如果掌握了它,就掌握了ajax!!!
1.得到XMLHttpRequest
大多數(shù)瀏覽器都支持:var xmlHttp=new XMLHttpRequest();
IE6.0:var xmlHttp=new ActiveXObject(“Msxml2.XMLHTTP”);
IE5.0以更早版本的IE:var xmlHttp=new ActiveXObject(“Microsoft.XMLHTTP”);
2.編寫創(chuàng)建XMLHttpRequest對(duì)象的函數(shù)
function createXMLHttpRequest(){ try{ return new XMLHttpRequest(); } catch(e){ try{ return new ActiveXObject(“Msxml2.XMLHTTP”); }catch(e){ try{ return new ActiveXObject(“Microsoft.XMLHTTP”); }catch(e){ alert(“哥們兒,你用的是什么瀏覽器啊?”); throw e; } } } }
第二步(打開與服務(wù)器的連接)
xmlHttp.open():用來打開與服務(wù)器的連接,它需要三個(gè)參數(shù):
請(qǐng)求方式:可以是GET與POST
請(qǐng)求的URL:指定服務(wù)器端資源,例如:/day23_1/AServlet
請(qǐng)求是否為異步:如果為true表示發(fā)送異步請(qǐng)求,否則同步請(qǐng)求
xmlHttp.open(“GET”,”/day23_1/AServlet”,true);//比如
第三步(發(fā)送請(qǐng)求)
xmlHttp.send(null):如果不給可能會(huì)造成部分瀏覽器無法發(fā)送!
參數(shù):就是請(qǐng)求體內(nèi)容!如果是GET請(qǐng)求,必須給出null。
如果是POST請(qǐng)求,如下
xmlHttp.send(“username=zhangSan&password=123”);
第四步:
在xmlHttp對(duì)象的一個(gè)事件上注冊(cè)監(jiān)聽器:onreadystatechange
xmlHttp對(duì)象一共有5個(gè)狀態(tài)
0:初始化未完成狀態(tài),只是創(chuàng)建了XMLHttpRequest對(duì)象,還未調(diào)用open()方法
1:請(qǐng)求已開始,open()方法已調(diào)用,但還沒調(diào)用send()方法
2:請(qǐng)求發(fā)送完成狀態(tài),send()方法已調(diào)用
3:開始讀取服務(wù)器響應(yīng)
4:讀取服務(wù)器響應(yīng)結(jié)束(通常我們只關(guān)心最后這個(gè)狀態(tài)!!!)
得到xmlHttp對(duì)象的狀態(tài)
var state = xmlHttp.readyState;//可能是0、1、2、3、4
得到服務(wù)器響應(yīng)的狀態(tài)碼(200:成功 304:狀態(tài)沒有改變 404 500:服務(wù)器錯(cuò)誤)
var status=xmlHttp.status;//例如200、404、500
得到服務(wù)器響應(yīng)的內(nèi)容
var content=xmlHttp.responseText;//得到服務(wù)器的響應(yīng)的文本格式的內(nèi)容(這更通用) var content=xmlHttp.responseXML;//得到服務(wù)器的響應(yīng)的xml響應(yīng)的內(nèi)容,它是document對(duì)象了!
所以監(jiān)聽器應(yīng)該這樣寫
xmlHttp.onreadystatechange = function(){ //xmlHttp的5種狀態(tài)都會(huì)調(diào)用本方法 if(xmlHttp.readyState ==4 && xmlHttp.status == 200){ //雙重判斷:判斷是否為4狀態(tài),而且還要判斷是否為200 var text=xmlHttp.responseText; } };
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- jquery的ajax異步請(qǐng)求接收返回json數(shù)據(jù)實(shí)例
- SpringMVC環(huán)境下實(shí)現(xiàn)的Ajax異步請(qǐng)求JSON格式數(shù)據(jù)
- ajax 同步請(qǐng)求和異步請(qǐng)求的差異分析
- ajax異步請(qǐng)求詳解
- Vue form 表單提交+ajax異步請(qǐng)求+分頁效果
- AJAX實(shí)現(xiàn)簡(jiǎn)單的注冊(cè)頁面異步請(qǐng)求實(shí)例代碼
- dojo學(xué)習(xí)第二天 ajax異步請(qǐng)求之綁定列表
- ajax的工作原理以及異步請(qǐng)求的封裝介紹
- 基于JQuery的$.ajax方法進(jìn)行異步請(qǐng)求導(dǎo)致頁面閃爍的解決辦法
- Ajax異步請(qǐng)求JSon數(shù)據(jù)(圖文詳解)
相關(guān)文章
AJAX和三層架構(gòu)實(shí)現(xiàn)分頁功能具體思路及代碼
本文涉及到AJAX和三層架構(gòu)方面的知識(shí),在學(xué)習(xí)分頁的同時(shí)也鞏固了一下它們的相關(guān)知識(shí),適合初學(xué)者的你2013-05-05AJAX 動(dòng)態(tài)加載后臺(tái)數(shù)據(jù) 綁定select的方法
今天小編就為大家分享一篇AJAX 動(dòng)態(tài)加載后臺(tái)數(shù)據(jù) 綁定select的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-08-08在dom4j中使用XPath的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)硪黄赿om4j中使用XPath的簡(jiǎn)單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-09-09ajax三級(jí)聯(lián)動(dòng)下拉菜單效果
這篇文章主要為大家詳細(xì)介紹了ajax三級(jí)聯(lián)動(dòng)下拉菜單的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03Ajax發(fā)送和接收二進(jìn)制字節(jié)流數(shù)據(jù)的方法
這篇文章主要介紹了Ajax發(fā)送和接收二進(jìn)制字節(jié)流數(shù)據(jù)的方法,非常不錯(cuò),具有參考借鑒價(jià)值,感興趣的朋友一起看看吧2016-05-05jQuery中ajax - post() 方法實(shí)例詳解
在jquery中的ajax有二個(gè)數(shù)據(jù)發(fā)送模式,一種是get,另一種是post(),下面我來給大家介紹介紹,有需要了解的朋友可參考2015-09-09asp.net+ajax簡(jiǎn)單分頁實(shí)例分析
這篇文章主要介紹了asp.net+ajax簡(jiǎn)單分頁實(shí)現(xiàn)方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了ajax分頁的具體實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-12-12