首先瘦馍,ajax是一種技術(shù),實(shí)現(xiàn)網(wǎng)頁(yè)部分?jǐn)?shù)據(jù)的刷新应役,那么ajax是怎么實(shí)現(xiàn)的呢情组?先看一下基礎(chǔ)版的ajax封裝:
var xml=new XMLHttpRequest()
xml.open('get',url,false)
xml.onreadystatechange=function(){
if(xhr.readyState==4){
if(xhr.status==200||xhr.status==304){
console.log(xhr.responseText)
}
}
}
xml.send()
xml.open('post',url,false)
xml.setRequestHeader('Content-type','application/x-www-urlencoded')
xml.onreadystatechange=function(){
if(xhr.readyState==4){
if(xhr.status==200||xhr.status==304){
console.log(xhr.responseText)
}
}
}
xml.send()
可以看出這就是XML的基本使用,其實(shí)無(wú)論jquery的ajax方法箩祥,還是axios院崇,都是基于XML進(jìn)行封裝的。
jquery的ajax方法的使用場(chǎng)景和優(yōu)缺點(diǎn)
使用場(chǎng)景:
一些沒(méi)有使用框架的項(xiàng)目中袍祖,因?yàn)榛卷?xiàng)目中引入jquery會(huì)節(jié)省很多操作底瓣,而jquery對(duì)ajax也進(jìn)行了封裝,能兼容各個(gè)瀏覽器蕉陋。
優(yōu)點(diǎn):
兼容性高捐凭,能在各個(gè)瀏覽器中使用,而且簡(jiǎn)化了使用
增加了對(duì)jsonp的支持凳鬓,可以支持簡(jiǎn)單的跨域
缺點(diǎn):
如果有多個(gè)請(qǐng)求茁肠,且有依賴關(guān)系,很容易形成回調(diào)地獄
本身是針對(duì)MVC的編程缩举,不符合現(xiàn)在MVVM的潮流
如果只使用ajax這個(gè)方法垦梆,還要引入整個(gè)jquery庫(kù),得不償失
axios的使用場(chǎng)景和優(yōu)缺點(diǎn)
使用場(chǎng)景:
各個(gè)支持高級(jí)語(yǔ)法的地方仅孩,因?yàn)閍xios是基于Promise進(jìn)行封裝的
優(yōu)點(diǎn):
支持Promise Api
有請(qǐng)求和發(fā)送攔截托猩,可以進(jìn)行處理
傳喚請(qǐng)求數(shù)據(jù)和響應(yīng)數(shù)據(jù)
客戶端支持防御XSRF
缺點(diǎn):
值適用于高版本瀏覽器
fetch的使用場(chǎng)景和優(yōu)缺點(diǎn)
fetch是低層次的API,代替XHR辽慕,可以輕松處理各種格式京腥,非文本化格式〗︱龋可以很容易的被其他技術(shù)使用公浪,例如Service Workers摆尝。但是想要很好的使用fetch,需要做一些封裝處理
fetch("http://example.com/movies.json")
.then(function(response) {
return response.json();
})
.then(function(myJson) {
console.log(myJson);
});
優(yōu)勢(shì)
跨域很簡(jiǎn)單
fetch({
url:'api/index',
method:'post',
mode:'no-cors',
})
劣勢(shì):
fetch只對(duì)網(wǎng)絡(luò)請(qǐng)求報(bào)錯(cuò)因悲,對(duì)400,500都當(dāng)做成功的請(qǐng)求勺爱,需要封裝去處理
fetch默認(rèn)不會(huì)帶cookie晃琳,需要添加配置項(xiàng)。
fetch不支持abort琐鲁,不支持超時(shí)控制卫旱,使用setTimeout及Promise.reject的實(shí)現(xiàn)超時(shí)控制并不能阻止請(qǐng)求過(guò)程繼續(xù)在后臺(tái)運(yùn)行,造成了流量的浪費(fèi)围段。
fetch沒(méi)有辦法原生監(jiān)測(cè)請(qǐng)求的進(jìn)度顾翼,而XHR可以。