原生js實(shí)現(xiàn)Ajax

原生js實(shí)現(xiàn)Ajax方法:
var Ajax={
get: function(url, fn) { var xhr = new XMLHttpRequest(); // XMLHttpRequest對(duì)象用于在后臺(tái)與服務(wù)器交換數(shù)據(jù)
xhr.open('GET', url, true);
xhr.onreadystatechange = function() { if (xhr.readyState == 4 && xhr.status == 200 || xhr.status == 304) { // readyState == 4說明請(qǐng)求已完成
fn.call(this, xhr.responseText); //從服務(wù)器獲得數(shù)據(jù)
}
};
xhr.send();
},
post: function (url, data, fn) { // datat應(yīng)為'a=a1&b=b1'這種字符串格式汹来,在jq里如果data為對(duì)象會(huì)自動(dòng)將對(duì)象轉(zhuǎn)成這種字符串格式
var xhr = new XMLHttpRequest();
xhr.open("POST", url, true);
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); // 添加http頭房交,發(fā)送信息至服務(wù)器時(shí)內(nèi)容編碼類型
xhr.onreadystatechange = function() { if (xhr.readyState == 4 && (xhr.status == 200 || xhr.status == 304)) { // 304未修改
fn.call(this, xhr.responseText);
}
};
xhr.send(data);
}
}

注釋:

  1. open(method, url, async) 方法需要三個(gè)參數(shù):

method:發(fā)送請(qǐng)求所使用的方法(GET或POST)赏半;與POST相比,GET更簡單也更快,并且在大部分情況下都能用右蹦;然而昨悼,在以下情況中,請(qǐng)使用POST請(qǐng)求:

  • 無法使用緩存文件(更新服務(wù)器上的文件或數(shù)據(jù)庫)
  • 向服務(wù)器發(fā)送大量數(shù)據(jù)(POST 沒有數(shù)據(jù)量限制)
  • 發(fā)送包含未知字符的用戶輸入時(shí),POST 比 GET 更穩(wěn)定也更可靠

url:規(guī)定服務(wù)器端腳本的 URL(該文件可以是任何類型的文件轨蛤,比如 .txt 和 .xml蜜宪,或者服務(wù)器腳本文件,比如 .asp 和 .php (在傳回響應(yīng)之前祥山,能夠在服務(wù)器上執(zhí)行任務(wù)))圃验;

async:規(guī)定應(yīng)當(dāng)對(duì)請(qǐng)求進(jìn)行異步(true)或同步(false)處理;true是在等待服務(wù)器響應(yīng)時(shí)執(zhí)行其他腳本缝呕,當(dāng)響應(yīng)就緒后對(duì)響應(yīng)進(jìn)行處理澳窑;false是等待服務(wù)器響應(yīng)再執(zhí)行。

  1. send() 方法可將請(qǐng)求送往服務(wù)器供常。

  2. onreadystatechange:存有處理服務(wù)器響應(yīng)的函數(shù)摊聋,每當(dāng) readyState 改變時(shí),onreadystatechange 函數(shù)就會(huì)被執(zhí)行栈暇。

  3. readyState:存有服務(wù)器響應(yīng)的狀態(tài)信息麻裁。

  • 0: 請(qǐng)求未初始化(代理被創(chuàng)建,但尚未調(diào)用 open() 方法)
  • 1: 服務(wù)器連接已建立(open方法已經(jīng)被調(diào)用)
  • 2: 請(qǐng)求已接收(send方法已經(jīng)被調(diào)用源祈,并且頭部和狀態(tài)已經(jīng)可獲得)
  • 3: 請(qǐng)求處理中(下載中煎源,responseText 屬性已經(jīng)包含部分?jǐn)?shù)據(jù))
  • 4: 請(qǐng)求已完成,且響應(yīng)已就緒(下載操作已完成)
  1. responseText:獲得字符串形式的響應(yīng)數(shù)據(jù)香缺。
  2. setRequestHeader():POST傳數(shù)據(jù)時(shí)手销,用來添加 HTTP 頭,然后send(data)图张,注意data格式锋拖;GET發(fā)送信息時(shí)直接加參數(shù)到url上就可以。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末祸轮,一起剝皮案震驚了整個(gè)濱河市姑隅,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌倔撞,老刑警劉巖讲仰,帶你破解...
    沈念sama閱讀 222,183評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異痪蝇,居然都是意外死亡鄙陡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門躏啰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來趁矾,“玉大人,你說我怎么就攤上這事给僵『恋罚” “怎么了详拙?”我有些...
    開封第一講書人閱讀 168,766評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵,是天一觀的道長蔓同。 經(jīng)常有香客問我饶辙,道長,這世上最難降的妖魔是什么斑粱? 我笑而不...
    開封第一講書人閱讀 59,854評(píng)論 1 299
  • 正文 為了忘掉前任弃揽,我火速辦了婚禮,結(jié)果婚禮上则北,老公的妹妹穿的比我還像新娘矿微。我一直安慰自己,他們只是感情好尚揣,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評(píng)論 6 398
  • 文/花漫 我一把揭開白布涌矢。 她就那樣靜靜地躺著,像睡著了一般快骗。 火紅的嫁衣襯著肌膚如雪蒿辙。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,457評(píng)論 1 311
  • 那天滨巴,我揣著相機(jī)與錄音,去河邊找鬼俺叭。 笑死恭取,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的熄守。 我是一名探鬼主播蜈垮,決...
    沈念sama閱讀 40,999評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼裕照!你這毒婦竟也來了攒发?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,914評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤晋南,失蹤者是張志新(化名)和其女友劉穎惠猿,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體负间,經(jīng)...
    沈念sama閱讀 46,465評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡偶妖,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了政溃。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片趾访。...
    茶點(diǎn)故事閱讀 40,675評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖董虱,靈堂內(nèi)的尸體忽然破棺而出扼鞋,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 36,354評(píng)論 5 351
  • 正文 年R本政府宣布云头,位于F島的核電站捐友,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏盘寡。R本人自食惡果不足惜楚殿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評(píng)論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望竿痰。 院中可真熱鬧脆粥,春花似錦、人聲如沸影涉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蟹倾。三九已至匣缘,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間鲜棠,已是汗流浹背肌厨。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評(píng)論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留豁陆,地道東北人柑爸。 一個(gè)月前我還...
    沈念sama閱讀 49,091評(píng)論 3 378
  • 正文 我出身青樓,卻偏偏與公主長得像盒音,于是被迫代替她去往敵國和親表鳍。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評(píng)論 2 360

推薦閱讀更多精彩內(nèi)容