前言
其實AJAX內部實現并不麻煩,主要通過一個叫XMLHttpRequest的對象,而這個對象在現有的瀏覽器均被支持。
可以說,它是整個AJAX實現的基礎,是瀏覽器用于后臺與服務器交換數據的對象,有了它,才有了AJAX,也便有了部分頁面刷新的藝術!
本文主要給大家介紹了關于Ajax原理以及代碼封裝的相關內容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。
示例代碼
步驟:
1、創建。
創建 XMLHttpRequest 對象的語法:
老版本的 Internet Explorer (IE5 和 IE6)使用 ActiveX 對象:
2、連接和發送。
2.1、open()函數的三個參數:請求方式、請求地址、是否異步請求
2.2、GET 請求方式是通過URL參數將數據提交到服務器的,POST則是通過將數據作為 send 的參數提交到服務器
2.3、POST 請求中,在發送數據之前,要設置表單提交的內容類型
2.3、提交到服務器的參數必須經過 encodeURIComponent()
方法進行編碼,實際上在參數列表key=value的形式中,key 和 value 都需要進行編碼,因為會包含特殊字符。每次請求的時候都會在參數列表中拼入一個 v=xx 的字符串,這樣是為了拒絕緩存,每次都直接請求到服務器上。
3、接收。
3.1、接收到響應后,響應的數據會自動填充XHR對象,相關屬性如下
responseText:響應返回的主體內容,為字符串類型;
responseXML:如果響應的內容類型是 "text/xml" 或 "application/xml",這個屬性中將保存著相應的xml 數據,是 XML 對應的 document 類型;
status:響應的HTTP狀態碼;
statusText:HTTP狀態的說明
3.2、XHR對象的readyState屬性表示請求/響應過程的當前活動階段,這個屬性的值如下
0 --> 未初始化,尚未調用open()
方法;
1 --> 啟動,調用了open()
方法,未調用send()
方法;
2 --> 發送,已經調用了send()
方法,未接收到響應;
3 --> 接收,已經接收到部分響應數據;
4 --> 完成,已經接收到全部響應數據;
只要 readyState 的值變化,就會調用 readystatechange 事件,(其實為了邏輯上通順,可以把readystatechange放到send之后,因為send時請求服務器,會進行網絡通信,需要時間,在send之后指定readystatechange事件處理程序也是可以的,我一般都是這樣用,但為了規范和跨瀏覽器兼容性,還是在open之前進行指定吧)。
3.3、在readystatechange事件中,先判斷響應是否接收完成,然后判斷服務器是否成功處理請求,xhr.status
是狀態碼,狀態碼以2開頭的都是成功,304表示從緩存中獲取,上面的代碼在每次請求的時候都加入了隨機數,所以不會從緩存中取值,故該狀態不需判斷。
封裝ajax方法:
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com