區別:1、fetch沒有辦法原生監控請求的進度,而ajax基於原生的XHR開發,可以監控;2、和ajax相比,fetch有著更好更方便的寫法;3、fetch只對網路請求報錯,對400、500都當做成功的請求,而ajax不會。
本教學操作環境:windows7系統、jquery1.10.2版本、Dell G3電腦。
ajax和fetch的區別:
#(1)、ajax是利用XMLHttpRequest物件來請求資料的,而fetch是window的一個方法
(2)、ajax基於原生的XHR開發,XHR本身的架構不清晰,已經有了fetch的替代方案
(3)、fetch比較與ajax有著更好更方便的寫法
(4)、fetch只對網路請求報錯,對400,500都當做成功的請求,需要封裝去處理
(5)、fetch沒有辦法原生監控請求的進度,而XHR可以
ajax用法
因為它原生的寫法很雞肋,所以大多會封裝下,導致可能很多人不會自己寫個ajax請求。都是用的JQuery或Axios來請求資料的
var xhr= new XMLHttpRequest(); // 新建XMLHttpRequest对象 xhr.onload= function(){ //请求完成 console.log(this.responseText); } // 发送请求: xhr.open('GET', '/user'); xhr.send();
這樣一個請求就發出去了。很麻煩,發個簡單請求,還得寫這麼多行程式碼。實際開發當然不會這麼寫,否則程式碼冗餘,可讀性差,用promise封裝一下
var Ajax = { get: function(url,fn){ // XMLHttpRequest对象用于在后台与服务器交换数据 var xhr=new XMLHttpRequest(); xhr.open('GET',url,false); xhr.onreadystatechange=function(){ // readyState == 4说明请求已完成 if(xhr.readyState==4){ if(xhr.status==200 || xhr.status==304){ console.log(xhr.responseText); fn.call(xhr.responseText); } } } xhr.send(); }, // data应为'a=a1&b=b1'这种字符串格式,在jq里如果data为对象会自动将对象转成这种字符串格式 post: function(url,data,fn){ var xhr=new XMLHttpRequest(); xhr.open('POST',url,false); // 添加http头,发送信息至服务器时内容编码类型 xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded'); xhr.onreadystatechange=function(){ if (xhr.readyState==4){ if (xhr.status==200 || xhr.status==304){ // console.log(xhr.responseText); fn.call(xhr.responseText); } } } xhr.send(data); } }
程式碼註解:
1、open (method, url, async)
方法需要三個參數:
method:發送請求所使用的方法(GET或POST);與POST相比,GET更簡單也更快,而且在大部分情況下都能用;然而,在以下情況中,請使用POST請求:
①無法使用快取檔案(更新伺服器上的檔案或資料庫)
②傳送大量資料(POST 沒有資料量限制)
③傳送包含未知字元的使用者輸入時,POST 比GET 更穩定也更可靠
6.setRequestHeader():POST傳資料時,用來加入HTTP 頭,然後send(data),注意data格式;GET傳送訊息時直接加參數到url上就可以,例如url?a=a1&b=b1。
fetch用法
#1、第一個參數是URL2、第二個參數可選參數可以控制不同的init物件3、使用了js 中的promise物件
var arr1 = [{ name: "haha", detail:"123" }]; fetch("url", { method: "post", headers: {//设置请求的头部信息 "Content-Type": "application/json" //跨域时可能要加上 //"Accept":"allication/json" }, //将arr1对象序列化成json字符串 body: JSON.stringify(arr1)//向服务端传入json数据 }).then(function(resp) { resp.json().then((data) => { }) });###所有的IE瀏覽器都不會支援fetch()方法,伺服器端回傳狀態碼400 500的時候不會reject######【相關教學推薦:###AJAX影片教學###】####
以上是ajax和fetch有什麼差別的詳細內容。更多資訊請關注PHP中文網其他相關文章!