請(qǐng)求方式,分為GET與POST: GET 最為常見的HTTP請(qǐng)求,普通上網(wǎng)瀏覽頁(yè)面就是GET。GET方式的參數(shù)請(qǐng)求直接跟在URL后,以問(wèn)號(hào)開始。(JS中用window.location.search獲得)。參數(shù)可以用encodeURIComponent進(jìn)行編碼,使用方式:
var EnParam = encodeURIComponent(param);
URL只支持大約2K的長(zhǎng)度,即2048字符數(shù);使用GET進(jìn)行AJAX請(qǐng)求時(shí)候會(huì)緩存導(dǎo)致出現(xiàn)的頁(yè)面不是正確的,一般方法加random參數(shù)值;ajax.send(null)。
POST
向服務(wù)器提交數(shù)據(jù)用到。
需要將form表單中的值先取出轉(zhuǎn)換成字符串,用&符號(hào)連接,(同GET傳參數(shù)一樣);提交數(shù)據(jù)量2GB ;使用ajax.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'),處理提交的字符串;ajax.send(strings),這個(gè)strings表示form中需要提交的內(nèi)容,例如a=1&b=2類似這樣的字符串。
同步與異步:
ajax.open方法中,第3個(gè)參數(shù)是設(shè)同步或者異步。prototype等js類庫(kù)一般都默認(rèn)為異步,即設(shè)為true。先說(shuō)下同步的情況下,js會(huì)等待請(qǐng)求返回,獲取status。不需要onreadystatechange事件處理函數(shù)。而異步則需要onreadystatechange事件處理,且值為4再正確處理下面的內(nèi)容。
(注:文中的 ajax 表示XMLHTTP請(qǐng)求對(duì)象。)
新聞熱點(diǎn)
疑難解答
圖片精選