jQuery bietet einfache und leistungsstarke Auswahlfunktionen und bietet außerdem gute Unterstützung für Ajax-Operationen. In Bezug auf Ajax stellt jQuery neben der zugrunde liegenden Methode jQuery.ajax() auch die folgenden einfachen Methoden bereit:
(1) jQuery.get(url, [data], [callback], [type])
(2) jQuery.getJSON(url, [data], [callback])
(3) jQuery.getScript(url, [callback])
(4) jQuery.post(url, [data], [callback], [type])
Da jQuery.ajax() relativ leistungsfähig ist und über viele konfigurierbare Parameter verfügt, werden wir nun hauptsächlich die Vorsichtsmaßnahmen für diese Methode zusammenfassen.
1. jQuery.ajax() wird standardmäßig asynchron angefordert. Wenn eine Synchronisierung erforderlich ist, verwenden Sie den Parameter async auf false. Weil einige Anwendungen Daten synchron anfordern müssen. Beispielsweise erfordert die Anforderung einer JS-Funktion in einigen interaktiven Flash- und JS-Anwendungen sofortige Rückgabedaten. Zu diesem Zeitpunkt muss der synchrone Ajax-Aufruf verwendet werden.
2. Wenn es sich bei Ajax um eine Get-Anfrage handelt, werden die zurückgegebenen Daten im Allgemeinen vom Browser zwischengespeichert. Wenn Sie nicht möchten, dass sie zwischengespeichert werden, können Sie den Cache-Parameter auf „false“ setzen oder die Anfrage mit einem Zeitstempel senden dass der Browser beim erneuten Laden der Daten vom Server davon ausgeht, dass es sich um eine neue Anfrage handelt. Wenn die Anfrage per POST gesendet wird, wird sie natürlich nicht zwischengespeichert.
3. Datentyp: Der vom Server erwartete Datentyp. Wenn nicht angegeben, gibt jQuery automatisch ResponseXML oder ResponseText basierend auf den MIME-Informationen des HTTP-Pakets zurück und übergibt sie als Callback-Funktionsparameter. Verfügbare Werte:
(1) „xml“: Gibt ein XML-Dokument zurück, das mit jQuery verarbeitet werden kann.
(2) „html“: Gibt reine Text-HTML-Informationen zurück; das enthaltene Skript-Tag wird ausgeführt, wenn es in den Dom eingefügt wird.
(3) „script“: Gibt JavaScript-Code im Klartext zurück. Ergebnisse werden nicht automatisch zwischengespeichert. Es sei denn, der Parameter „Cache“ ist gesetzt. '''Hinweis:''''Bei Remote-Anfragen (nicht unter derselben Domäne) werden alle POST-Anfragen in GET-Anfragen umgewandelt. (Da zum Laden das DOM-Skript-Tag verwendet wird)
(4) „json“: JSON-Daten zurückgeben.
(5) „jsonp“: JSONP-Format. Beim Aufrufen einer Funktion im JSONP-Format, z. B. „myurl?callback=?“, ersetzt jQuery automatisch ? durch den richtigen Funktionsnamen, um die Callback-Funktion auszuführen.
(6) „text“: Gibt eine reine Textzeichenfolge zurück
Unter anderem können die Einstellungen „script“ und „json“ das domänenübergreifende Problem von Ajax lösen.
4. Wenn der Server eine Zeichenfolge oder einen numerischen Wert zurückgibt, verwenden Sie einfach einen gewöhnlichen Ajax-Aufruf.
Wenn der Server ein JSON-Objekt zurückgibt, verwenden Sie am besten jQuery.getJSON oder setzen Sie dataType=json. Da der Browser Zeit benötigt, um das JSON-Objekt zu analysieren, spart die direkte Rückgabe des JSON-Objekts Zeit beim Parsen und vermeidet Fehler, bei denen der Server offensichtlich Daten zurückgibt, der Browser sie jedoch nicht abrufen kann.
5. Ajax-Aufrufe brauchen Zeit, daher werden im Allgemeinen alle Verarbeitungscodes nach Ajax-Aufrufen in der Rückrufmethode platziert. Dieser Ansatz kann nicht verwendet werden:
而必须这样处理:即将处理代码放到success函数里面!
6. jQuery.getJSON实例: