国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

關于Ajax的原理以及代碼封裝詳解

2024-05-06 15:27:02
字體:
來源:轉載
供稿:網友

前言

其實AJAX內部實現并不麻煩,主要通過一個叫XMLHttpRequest的對象,而這個對象在現有的瀏覽器均被支持。

可以說,它是整個AJAX實現的基礎,是瀏覽器用于后臺與服務器交換數據的對象,有了它,才有了AJAX,也便有了部分頁面刷新的藝術!

本文主要給大家介紹了關于Ajax原理以及代碼封裝的相關內容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。

示例代碼

var xmlhttp;if (window.XMLHttpRequest) { // code for IE7+, Firefox, Chrome, Opera, Safari xmlhttp = new XMLHttpRequest();} else { // code for IE6, IE5  xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");}xmlhttp.onreadystatechange = function() { if (xmlhttp.readyState == 4 && xmlhttp.status == 200){  // to do... }}xmlhttp.open("GET","test1.txt",true);xmlhttp.send();

步驟:

1、創建。

創建 XMLHttpRequest 對象的語法:

var = new XMLHttpRequest();

老版本的 Internet Explorer (IE5 和 IE6)使用 ActiveX 對象:

var = new ActiveXObject("Microsoft.XMLHTTP");

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之前進行指定吧)。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 平远县| 佳木斯市| 郎溪县| 长宁区| 抚顺县| 汽车| 仙桃市| 中超| 屯留县| 项城市| 富锦市| 高安市| 宜黄县| 嘉兴市| 永泰县| 文安县| 杂多县| 兴宁市| 淮北市| 红河县| 南漳县| 莱阳市| 灵武市| 铁岭县| 甘泉县| 青龙| 临沭县| 石柱| 邢台县| 社旗县| 内江市| 大冶市| 平利县| 沾化县| 日土县| 延津县| 云南省| 玉树县| 宁陕县| 西乡县| 湛江市|