Heim >Web-Frontend >js-Tutorial >Jquery Ajax-Fehlertipps zum Debuggen von Fehlern_jquery

Jquery Ajax-Fehlertipps zum Debuggen von Fehlern_jquery

WBOY
WBOYOriginal
2016-05-16 15:30:581794Durchsuche

JQuery ermöglicht es uns, die Effizienz zu verbessern und viele Kompatibilitätsprobleme bei der Entwicklung von Ajax-Anwendungen zu reduzieren. Was sollten wir tun, wenn beim asynchronen Abrufen von Daten durch Ajax ein Fehler auftritt? Information.

Bevor ich Ihnen den Haupttext vorstelle, möchte ich die detaillierte Liste der AJAX-Parameter in Jquery teilen:

Parametername Typ Beschreibung
URL Zeichenfolge (Standard: aktuelle Seitenadresse) Die Adresse zum Senden der Anfrage.
Typ Zeichenfolge (Standard: „GET“) Anforderungsmethode („POST“ oder „GET“), Standard ist „GET“. Hinweis: Andere HTTP-Anfragemethoden wie PUT und DELETE können ebenfalls verwendet werden, werden jedoch nur von einigen Browsern unterstützt.
Zeitüberschreitung Nummer Anfrage-Timeout festlegen (Millisekunden). Diese Einstellung überschreibt die globale Einstellung.
asynchron Boolescher Wert (Standard: true) Standardmäßig sind alle Anfragen asynchrone Anfragen. Wenn Sie synchrone Anfragen senden müssen, legen Sie diese Option auf „false“ fest. Beachten Sie, dass eine synchrone Anfrage den Browser sperrt und der Benutzer warten muss, bis die Anfrage abgeschlossen ist, bevor andere Vorgänge ausgeführt werden können.
beforeSend Funktion Die Funktionen des XMLHttpRequest-Objekts können vor dem Senden der Anfrage geändert werden, beispielsweise durch das Hinzufügen benutzerdefinierter HTTP-Header. Das XMLHttpRequest-Objekt ist der einzige Parameter.
<span>function</span> (XMLHttpRequest) {<br> <span>this</span>; <span>// the options for this ajax request</span><br>}
Cache Boolescher Wert (Standard: true) Neu in jQuery 1.2: Bei der Einstellung „false“ werden keine Anforderungsinformationen aus dem Browser-Cache geladen.
abgeschlossen Funktion Rückruffunktion nach Abschluss der Anfrage (wird aufgerufen, wenn die Anfrage erfolgreich ist oder fehlschlägt). Parameter: XMLHttpRequest-Objekt, Erfolgsinformationszeichenfolge.
<span>function</span> (XMLHttpRequest, textStatus) {<br> <span>this</span>; <span>// the options for this ajax request</span><br>}
contentType String (默认: "application/x-www-form-urlencoded") 发送信息至服务器时内容编码类型。默认值适合大多数应用场合。
data Object,
String
发 送到服务器的数据。将自动转换为请求字符串格式。GET 请求中将附加在 URL 后。查看 processData 选项说明以禁止此自动转换。必须为 Key/Value 格式。如果为数组,jQuery 将自动为不同值对应同一个名称。如 {foo:["bar1", "bar2"]} 转换为 '&foo=bar1&foo=bar2'。
dataType String

预期服务器返回的数据类型。如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息返回 responseXML 或 responseText,并作为回调函数参数传递,可用值:

"xml": 返回 XML 文档,可用 jQuery 处理。

"html": 返回纯文本 HTML 信息;包含 script 元素。

"script": 返回纯文本 JavaScript 代码。不会自动缓存结果。

"json": 返回 JSON 数据 。

"jsonp": JSONP 格式。使用 JSONP 形式调用函数时,如 "myurl?callback=?" jQuery 将自动替换 ? 为正确的函数名,以执行回调函数。

Fehler Funktion (Standard: Automatisch ermitteln (XML oder HTML)) Diese Methode wird aufgerufen, wenn die Anfrage fehlschlägt. Diese Methode benötigt drei Parameter: das XMLHttpRequest-Objekt, die Fehlermeldung und (möglicherweise) das erfasste Fehlerobjekt.
<span>function</span> (XMLHttpRequest, textStatus, errorThrown) {<br> <span>// 通常情况下textStatus和errorThown只有其中一个有值 </span><br> <span>this</span>; <span>// the options for this ajax request</span><br>}
global Boolean (默认: true) 是否触发全局 AJAX 事件。设置为 false 将不会触发全局 AJAX 事件,如 ajaxStart 或 ajaxStop 。可用于控制不同的Ajax事件
ifModified Boolean (默认: false) 仅在服务器数据改变时获取新数据。使用 HTTP 包 Last-Modified 头信息判断。
processData Boolean (默认: true) 默认情况下,发送的数据将被转换为对象(技术上讲并非字符串) 以配合默认内容类型 "application/x-www-form-urlencoded"。如果要发送 DOM 树信息或其它不希望转换的信息,请设置为 false。
success Function 请求成功后回调函数。这个方法有两个参数:服务器返回数据,返回状态
<span>function</span> (data, textStatus) {<br> <span>// data could be xmlDoc, jsonObj, html, text, etc...</span><br> <span>this</span>; <span>// the options for this ajax request</span><br>}

jquery中ajax的常用用法类似于:

JScript 代码  

$(document).ready(function() {
      jQuery("#clearCac").click(function() {
        jQuery.ajax({
          url: url,
          type: "post",
          data: { id: '0' },
          dataType: "json",
          success: function(msg) {
            alert(msg);
          },
          error: function(XMLHttpRequest, textStatus, errorThrown) {
            alert(XMLHttpRequest.status);
            alert(XMLHttpRequest.readyState);
            alert(textStatus);
          },
          complete: function(XMLHttpRequest, textStatus) {
            this; // 调用本次AJAX请求时传递的options参数
          }
        });
      });
    });

当通过ajax异步调用成功时,会调用 success函数 。success函数语法为:

 //请求成功后回调函数。这个方法有两个参数:服务器返回数据,返回状态


 function (data, textStatus)
 {
  // data could be xmlDoc, jsonObj, html, text, etc...   
  this;
 // the options for this ajax request
 }
当通过ajax异步调用出错时,会调用 error函数 。error函数语法为:
//(默 认: 自动判断 (xml 或 html)) 请求失败时调用时间。参数有以下三个:XMLHttpRequest 对象、错误信息、(可选)捕获的错误对象。如果发生了错误,错误信息(第二个参数)除了得到null之外,还可能是"timeout", "error", "notmodified" 和 "parsererror"。
//textStatus: "timeout", "error", "notmodified" 和 "parsererror"。
error:function (XMLHttpRequest, textStatus, errorThrown) 
{ 
} 

error事件返回的第一个参数XMLHttpRequest:

XMLHttpRequest.readyState: 状态码的意思

0 - (未初始化)还没有调用send()方法
1 - (载入)已调用send()方法,正在发送请求
2 - (载入完成)send()方法执行完成,已经接收到全部响应内容
3 - (交互)正在解析响应内容
4 - (完成)响应内容解析完成,可以在客户端调用了

发送error可能有下面两张引起的,或者其他程序问题,需要我们认真仔细。

1、data:"{}", data为空也一定要传"{}";不然返回的是xml格式的。并提示parsererror.
2、parsererror的异常和Header 类型也有关系。及编码header('Content-type: text/html; charset=utf8');

以上内容是小编给大家分享关于Jquery Ajax Error 调试错误的技巧,希望大家喜欢。

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn