您好,登錄后才能下訂單哦!
小編給大家分享一下ajax跨域請求中parsererror錯誤怎么辦,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
ajax請求報parsererror錯誤是很寬泛的概念,很多情況下都報這個錯,
在很多時候,即使ajax提交、返回都正常
XMLHttpRequest.status=200 (正常響應)
XMLHttpRequest.readyState=4 (正常接收)
ajax也會提示一個parseerror的錯誤.
出現這個錯誤,大都是不良書寫習慣,或者語法不當造成的.
關于ajax的錯誤,請使用:
error:function(XMLHttpRequest, textStatus, errorThrown){ $("div").html(textStatus); $("div").append("<br/>"XMLHttpRequest.status); $("div").append("<br/>"XMLHttpRequest.readyState); $("div").append("<br/>"XMLHttpRequest.responseText); }
或:
$("div").ajaxError(function(event,request, settings){ $(this).append("<li>出錯頁面:" + settings.url + "</li>"); });
取得錯誤相關信息,以進行分析.
textStatus返回除了得到null,"timeout", "error", "notmodified" 和 "parsererror"。
XMLHttpRequest對象可以使用status,readyState,responseText等屬性取得HTTP代碼,處理狀態和服務器返回的文字內容.
在使用ajax,以及相關應用開發過程中,一定要按標準寫程序,可以減少出錯的機率.
這個標準包括語法,數據格式,標點符號等.
ajax跨請求中,如果data為空,請使用;
data:"{}",
ajax處理服務器返回Json格式數據時,如果采用$.parseJSON()方式,
那么服務器返回的Json數據格式,一定按標準Json格式書寫,
對字符而言必須用雙引號代替單引號包圍,數值,布爾類型,null不用,
這點主要在一些老的jquery版本上發生單引號,雙引號的不同而出現錯誤提示.
ajax跨域請求(jsonp)中,服務端返回數據格式必須是:
myCallbackFunction({"id":1,"name":"C#","is_familiar":true});
請注意這個函數最后的分號";",必須加上,
否則,如果同一個頁面有多個ajax請求,并且在數據沒有返回時,再發出其它ajax請求時,
有可能出現parsererror出錯提示.
這種錯誤很隱敝,在開發時,不容易發現,在并發測試時,就很容易暴露出.
以上是“ajax跨域請求中parsererror錯誤怎么辦”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。