Heim > Web-Frontend > js-Tutorial > Verwendung der jQuery Ajax()-Methode guide_jquery

Verwendung der jQuery Ajax()-Methode guide_jquery

WBOY
Freigeben: 2016-05-16 16:30:54
Original
1556 Leute haben es durchsucht

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:

Code kopieren Der Code lautet wie folgt:

Funktion getMyPrizeList(){
    if(isNotEmpty(uid)){
        var obj=new Object();
        versuche es{
          jQuery.ajax({type:"GET",url:"someurl",async:false,cache:false,dataType:"script",scriptCharset:"gbk",success:function(json){
                     obj=json;
                  }
              });
           }catch(e){}
           obj=eval("(" obj ")");
           //alert(obj);
           var str="";
           for(var i in obj)
           {
               str ='' '' Prizearray[obj[i].prizeno] ''
               str ='' 'CD-KEY:' obj[i].cdkey ''
               str ='' '期限:' obj[i].expiratedate '前' '';
           }
           jQuery("#prizelist").append(str);
        }
}

而必须这样处理:即将处理代码放到success函数里面!

复制代码 代码如下:

Funktion getMyPrizeList(){
    if(isNotEmpty(uid)){
        var obj=new Array();
        versuche es{
                  jQuery.ajax({type:"GET",url:"someurl",
                               Cache:false,
                               dataType:"script",
                               scriptCharset:"gbk",
                               success:function(json){
                                 versuche es{
                                      obj=Ergebnis; 
                                }catch(e){}
                                jQuery("#preisliste").html("");
                                var str="";
                                for(var i=0;i                                     str ='' Prizearray[obj[i].prizeno] '';
                                    str ='CD-KEY:' obj[i].cdkey '';
                                    str ='期限:' obj[i].expiratedate '前';
                                }
                                jQuery("#preisliste").append(str);                  
                               }
                   });
           }catch(e){}
        }
}

6. jQuery.getJSON实例:

复制代码 代码如下:

//Interne Funktion zum Laden der Schuldnerdetails und zum Festlegen von Werten
Funktion innerShowDetail() {
// Daten im JSON-Format abrufen
         $.getJSON('load.do',{id : userId}, function(json) {
// Wert
basierend auf dem Schlüssel festlegen for (JSON-Eingabe) {
If(key == 'id'){
                           $('#detailDiv #' key).val(json[key]);
                 } sonst {
If(json[key] == ''){
                                                                                                                                                                                                                                                                          // Kein Wert auf leer gesetzt
                                $('#detailDiv #' key).html(' ');
                            } else if(key == 'sex'){
                           $('#detailDiv #' key).html(json[key] == '0' ? 'Female' : 'Male');
                            } else if(key == 'group'){
If(json[key] != null) {
$('#detailDiv #' key).html(json[key]['groupName']);
                    }
                      } sonst {
$('#detailDiv #' key).html(json[key]);
                 }
              }
           }
//Legen Sie den Dialogtitel und den Inhalt fest
               $('#detailDiv').removeAttr('class');
Dialog.setTitle('Person[' json['userName'] '] Details anzeigen');
Dialog.setContent($('#detailDiv').html());
});
}
Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage