HTTP報(bào)文及ajax基礎(chǔ)知識(shí)
HTTP報(bào)文
客戶端傳遞給服務(wù)器的內(nèi)容 和 服務(wù)器傳遞給客戶端的內(nèi)容 都屬于HTTP報(bào)文
起始行:請(qǐng)求起始行 響應(yīng)起始行
首部:請(qǐng)求首部 響應(yīng)首部 通用首部(請(qǐng)求和響應(yīng)都有的) 自定義首部
主體:請(qǐng)求主體 響應(yīng)主體
客戶端傳遞給服務(wù)器端數(shù)據(jù):
請(qǐng)求URL后面問號(hào)傳參的方式傳遞給服務(wù)器 /getList?name=zhangsan&age=7
設(shè)置請(qǐng)求的首部(設(shè)置請(qǐng)求頭信息)
設(shè)置請(qǐng)求主體,把傳遞給服務(wù)器的內(nèi)容放在請(qǐng)求主體中傳遞給服務(wù)器
服務(wù)器端傳遞給客戶端數(shù)據(jù):
設(shè)置響應(yīng)頭信息
設(shè)置響應(yīng)主體內(nèi)容
Ajax : async javascript and xml 異步的JS和XML(可擴(kuò)展的標(biāo)記語(yǔ)言,在XML文件中使用的標(biāo)簽都是自己擴(kuò)展的,利用自己擴(kuò)展的有規(guī)則的標(biāo)記來存儲(chǔ)相關(guān)的數(shù)據(jù))
Ajax是客戶端JS中的方法,用來向服務(wù)端發(fā)送請(qǐng)求(還可以傳遞給服務(wù)器端數(shù)據(jù)),然后把服務(wù)器端返回的內(nèi)容獲取到(Ajax一般是運(yùn)行在客戶端的瀏覽器中的)。
Ajax四步:
創(chuàng)建一個(gè)Ajax對(duì)象(下面的這種寫法在IE6及更低版本的瀏覽器中不支持)
var xhr = new XMLHttpRequest;
發(fā)送前的基本信息配置:配置請(qǐng)求方式(GET、POST、PUT、DELETE、HEAD...)
打開一個(gè)URL地址(配置向哪一個(gè)服務(wù)器地址發(fā)送請(qǐng)求)
同步還是異步(true代表異步 false代表同步 默認(rèn)是true)
[username]向服務(wù)器提供請(qǐng)求的用戶名
[userpass]向服務(wù)器提供請(qǐng)求的用戶密碼,這兩個(gè)值一般都不寫,只有服務(wù)器做了安全的限制,只允許特定的用戶訪問的話,我們才傳遞過去
xhr.open('get',"/data.txt",false,[username],[userpass]);
給onreadystatechange這個(gè)事件綁定一個(gè)方法,監(jiān)聽狀態(tài)的改變(只要狀態(tài)改變,就觸發(fā)方法執(zhí)行)
xhr.onreadystatechange = function(){
xhr.readyState:AJAX狀態(tài)碼,可以代表當(dāng)前處理的進(jìn)度
0 unset 當(dāng)前的請(qǐng)求還沒有發(fā)送
1 opened URL地址已經(jīng)打開(發(fā)送前的參數(shù)配置已經(jīng)完成)
2 headers_received 響應(yīng)頭信息已經(jīng)接受
3 loading 主要返回的內(nèi)容正在服務(wù)器端進(jìn)行準(zhǔn)備處理
4 done 響應(yīng)主體的內(nèi)容已經(jīng)成功返回給客戶端
xhr.status:HTTP網(wǎng)絡(luò)狀態(tài)碼,描述了服務(wù)器響應(yīng)內(nèi)容的狀態(tài)
200 OR ^2\d{2} (200或者以2開頭) -> 都代表響應(yīng)主體的內(nèi)容已經(jīng)成功返回了
301 永久重定向/永久轉(zhuǎn)移
302 臨時(shí)重定向/臨時(shí)轉(zhuǎn)移 服務(wù)器的負(fù)載均衡
304 本次獲取的內(nèi)容是讀取緩存中的數(shù)據(jù)
400 客戶端傳遞給服務(wù)器端的參數(shù)出現(xiàn)錯(cuò)誤
401 無(wú)權(quán)限訪問
404 客戶端訪問的地址不存在
500 未知的服務(wù)器錯(cuò)誤
503 服務(wù)器已經(jīng)超負(fù)荷
if(xhr.readyState===4 && /^2\d{2}$/.test(xhr.status)){ var val = xhr.responseText; } }
發(fā)送請(qǐng)求:參數(shù)是請(qǐng)求主體中傳遞給服務(wù)器的內(nèi)容
xhr.send(null);
總結(jié)
以上所述是小編給大家介紹的HTTP報(bào)文及ajax基礎(chǔ)知識(shí),希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
jQuery中ajax - get() 方法實(shí)例詳解
在JQuery中可以使用get,post和ajax方法給服務(wù)器端傳遞數(shù)據(jù),接下來,通過本篇文章給大家介紹jquery中ajax-get()方法實(shí)例詳解,有需要的朋友可以參考下2015-09-09使用ajax技術(shù)無(wú)刷新動(dòng)態(tài)調(diào)用新浪股票實(shí)時(shí)數(shù)據(jù)
由于最近網(wǎng)速慢的緣故,查看股票信息時(shí)網(wǎng)頁(yè)老是打不開。這幾天一直在研究ajax,于是用jquery自己做了一個(gè)自動(dòng)讀取新浪股票實(shí)時(shí)數(shù)據(jù)的頁(yè)面2014-08-08javascript 拖動(dòng)_cookie_ajax等
比較實(shí)用的js拖動(dòng)效果代碼。類的寫法不錯(cuò),是個(gè)不錯(cuò)的應(yīng)用2008-06-06ajax用json實(shí)現(xiàn)數(shù)據(jù)傳輸
本文主要介紹了ajax用json實(shí)現(xiàn)數(shù)據(jù)傳輸?shù)姆椒?,具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-03-03