Inhaltsverzeichnis
Erstellen
Anfrage senden
Antwort empfangen
同步
异步
超时
优化
Heim Web-Frontend js-Tutorial Verständnis von XHR-Objekten in Ajax-Serien

Verständnis von XHR-Objekten in Ajax-Serien

Jul 02, 2017 am 09:32 AM
ajax 理解

Vorherige Wörter

1999 veröffentlichte Microsoft IE5, der erstmals eine neue Funktion einführte: Javascript-Skripte können HTTP-Anfragen an den Server initiieren. Diese Funktion erregte damals keine große Aufmerksamkeit. Erst mit der Veröffentlichung von Gmail im Jahr 2004 und Google Map im Jahr 2005 erregte sie große Aufmerksamkeit. Im Februar 2005 wurde der Begriff Ajax erstmals offiziell vorgeschlagen und bezog sich auf eine Reihe von Entwicklungspraktiken rund um diese Funktion. Seitdem ist Ajax zum Synonym für skriptinitiierte HTTP-Kommunikation geworden, und W3C veröffentlichte 2006 auch seinen internationalen Standard. Dieser Artikel ist der erste Artikel in der Ajax-Reihe – Übersicht über XHR-Objekte

Ajax ist die Abkürzung für asynchrones Javascript und XML. Die chinesische Übersetzung ist asynchrones Javascript und XML Die zusätzlichen Daten des Servers, ohne dass die Seite entladen werden muss, führen zu einer besseren Benutzererfahrung. Obwohl der Name XML enthält, hat die Ajax-Kommunikation nichts mit dem Datenformat zu tun.

Ajax umfasst die folgenden Schritte: 1. Erstellen Sie ein AJAX-Objekt. 2. Senden Sie eine HTTP-Anfrage. 3. Empfangen Sie die vom Server zurückgegebenen Daten ; 4. Aktualisieren Sie die Webseitendaten

Zusammenfassend lässt sich sagen, dass Ajax eine HTTP-Anfrage über das native XMLHttpRequest-Objekt sendet und nach Erhalt der vom Server zurückgegebenen Daten

verarbeitet

Erstellen

Der Kern der Ajax-Technologie ist das XMLHttpRequest-Objekt (kurz XHR), eine Funktion, die erstmals von Microsoft eingeführt wurde. Andere Browseranbieter stellten später die gleiche Implementierung bereit. XHR bietet eine flüssige Schnittstelle zum Senden von Anforderungen an den Server und zum Parsen der Serverantwort. Es kann mehr Informationen vom Server asynchron abrufen, was bedeutet, dass der Benutzer nach dem Klicken neue Daten abrufen kann, ohne die Seite zu aktualisieren

IE5 Es war der erste Browser, der XHR-Objekte einführte. In IE5 wird das XHR-Objekt über ein ActiveX-Objekt in der MSXML-Bibliothek implementiert, während IE7+ und andere Standardbrowser native XHR-Objekte unterstützen

Das Erstellen eines XHR-Objekts wird auch als Instanziieren eines XHR-Objekts bezeichnet, da XMLHTTPRequest() dies ist ein Konstrukteur. Im Folgenden finden Sie die kompatible Methode zum Erstellen eines XHR-Objekts

Verständnis von XHR-Objekten in Ajax-Serien
var xhr;
if(window.XMLHttpRequest){
    xhr = new XMLHttpRequest();
}else{
    xhr = new ActiveXObject('Microsoft.XMLHTTP');
}
Nach dem Login kopieren
Verständnis von XHR-Objekten in Ajax-Serien

[Hinweis] Wenn Sie N verschiedene Anfragen erstellen möchten, müssen Sie N verschiedene XHR-Objekte verwenden. Es ist natürlich möglich, ein vorhandenes XHR-Objekt wiederzuverwenden, aber dadurch werden alle zuvor ausstehenden Anfragen über dieses Objekt beendet

Anfrage senden

open()

Bei Verwendung eines XHR-Objekts ist die erste aufzurufende Methode open(), wie unten gezeigt. Diese Methode akzeptiert 3 Parameter

xhr.open("get","example.php", false);
Nach dem Login kopieren

1 . Der erste Parameter der open()-Methode wird verwendet, um die Methode zum Senden der Anfrage anzugeben. Bei dieser Zeichenfolge wird die Groß- und Kleinschreibung nicht beachtet, es werden jedoch normalerweise Großbuchstaben verwendet. „GET“ und „POST“ werden weithin unterstützt

„GET“ wird für reguläre Anfragen verwendet. Es ist geeignet, wenn die URL die angeforderte Ressource vollständig angibt, wenn die Anfrage keine Nebenwirkungen auf den Server hat und wann Die Antwort des Servers ist verfügbar.

Die Methode „POST“ wird häufig in HTML-Formularen verwendet. Der Anfragetext enthält zusätzliche Daten, die häufig in einer Datenbank auf dem Server gespeichert werden. Wiederholte POST-Anfragen für dieselbe URL erhalten möglicherweise unterschiedliche Antworten vom Server, und Anfragen, die diese Methode verwenden, sollten nicht zwischengespeichert werden

Zusätzlich zu „GET“ und „POST“ können die Parameter auch „HEAD“ und sein „OPTIONEN“ „PUT“. Aufgrund von Sicherheitsrisiken ist die Verwendung von „CONNECT“, „TRACE“ und „TRACK“ verboten

[Hinweis] Die ausführliche Einführung in die 8 gängigen Methoden des HTTP-Protokolls wandert hierher

2 Der zweite Parameter der open()-Methode ist die URL, die relativ zur aktuellen Seite ist, auf der der Code ausgeführt wird, und kann nur Anfragen an URLs in derselben Domäne senden, die denselben Port und dasselbe Protokoll verwenden. Wenn zwischen der URL und der Seite, die die Anfrage initiiert, ein Unterschied besteht, tritt ein Sicherheitsfehler auf

3. Der dritte Parameter der open()-Methode ist ein boolescher Wert, der angibt, ob die Anfrage asynchron gesendet werden soll. Wenn nicht ausgefüllt, ist der Standardwert wahr. Zeigt asynchrones Senden an

4. Wenn Sie eine passwortgeschützte URL anfordern, übergeben Sie den Benutzernamen und das Passwort, die für die Authentifizierung verwendet werden, als 4. und 5. Parameter an die open()-Methode

send()

Die send()-Methode empfängt einen Parameter, bei dem es sich um die Daten handelt, die als Anforderungstext gesendet werden sollen. Nach dem Aufruf der send()-Methode wird die Anfrage an den Server gesendet

Wenn es sich um die GET-Methode handelt, hat die send()-Methode keine Parameter, oder der Parameter ist null, wenn es sich um die POST-Methode handelt. Die Parameter der send()-Methode sind diejenigen, die gesendet werden sollen. Daten

xhr.open("get", "example.txt", false);
xhr.send(null);
Nach dem Login kopieren

Antwort empfangen

Eine vollständige HTTP-Antwort besteht bestehend aus Statuscode, Antwort-Header-Sammlung und Antworttext. Nach Erhalt der Antwort können diese über die Eigenschaften und Methoden des XHR-Objekts verwendet werden. Es gibt hauptsächlich die folgenden 4 Eigenschaften

responseText: 作为响应主体被返回的文本(文本形式)
responseXML: 如果响应的内容类型是'text/xml'或'application/xml',这个属性中将保存着响应数据的XML DOM文档(document形式)
status: HTTP状态码(数字形式)
statusText: HTTP状态说明(文本形式)
Nach dem Login kopieren

  在接收到响应后,第一步是检查status属性,以确定响应已经成功返回。一般来说,可以将HTTP状态码为200作为成功的标志。此时,responseText属性的内容已经就绪,而且在内容类型正确的情况下,responseXML也可以访问了。此外,状态码为304表示请求的资源并没有被修改,可以直接使用浏览器中缓存的版本;当然,也意味着响应是有效的

  无论内容类型是什么,响应主体的内容都会保存到responseText属性中,而对于非XML数据而言,responseXML属性的值将为null

if((xhr.status >=200 && xhr.status 
Nach dem Login kopieren

 

同步

  如果接受的是同步响应,则需要将open()方法的第三个参数设置为false,那么send()方法将阻塞直到请求完成。一旦send()返回,仅需要检查XHR对象的status和responseText属性即可

  同步请求是吸引人的,但应该避免使用它们。客户端javascript是单线程的,当send()方法阻塞时,它通常会导致整个浏览器UI冻结。如果连接的服务器响应慢,那么用户的浏览器将冻结

Verständnis von XHR-Objekten in Ajax-Serien
<button>获取信息</button>
<div></div>
<script>
btn.onclick = function(){
    //创建xhr对象
    var xhr;
    if(window.XMLHttpRequest){
        xhr = new XMLHttpRequest();
    }else{
        xhr = new ActiveXObject(&#39;Microsoft.XMLHTTP&#39;);
    }
    //发送请求
    xhr.open(&#39;get&#39;,&#39;/uploads/rs/26/ddzmgynp/message.xml&#39;,false);
    xhr.send();
    //同步接受响应
    if(xhr.readyState == 4){
        if(xhr.status == 200){
            //实际操作
            result.innerHTML += xhr.responseText;
        }
    }
}
</script>
Nach dem Login kopieren
Verständnis von XHR-Objekten in Ajax-Serien
//message.xml
<p>hello world</p>
Nach dem Login kopieren
Nach dem Login kopieren

 

 

异步

  如果需要接收的是异步响应,这就需要检测XHR对象的readyState属性,该属性表示请求/响应过程的当前活动阶段。这个属性可取的值如下:

0(UNSENT):未初始化。尚未调用open()方法
1(OPENED):启动。已经调用open()方法,但尚未调用send()方法
2(HEADERS_RECEIVED):发送。己经调用send()方法,且接收到头信息
3(LOADING):接收。已经接收到部分响应主体信息
4(DONE):完成。已经接收到全部响应数据,而且已经可以在客户端使用了
Nach dem Login kopieren

  理论上,只要readyState属性值由一个值变成另一个值,都会触发一次readystatechange事件。可以利用这个事件来检测每次状态变化后readyState的值。通常,我们对readyState值为4的阶段感兴趣,因为这时所有数据都已就绪

  [注意]必须在调用open()之前指定onreadystatechange 事件处理程序才能确保跨浏览器兼容性,否则将无法接收readyState属性为0和1的情况

Verständnis von XHR-Objekten in Ajax-Serien
xhr.onreadystatechange = function(){
    if(xhr.readyState === 4){
        if(xhr.status == 200){
            alert(xhr.responseText);
        }
    }
}
Nach dem Login kopieren
Verständnis von XHR-Objekten in Ajax-Serien
Verständnis von XHR-Objekten in Ajax-Serien
<button>获取信息</button>
<div></div>
<script>
btn.onclick = function(){
    //创建xhr对象
    var xhr;
    if(window.XMLHttpRequest){
        xhr = new XMLHttpRequest();
    }else{
        xhr = new ActiveXObject(&#39;Microsoft.XMLHTTP&#39;);
    }
    //异步接受响应
    xhr.onreadystatechange = function(){
        if(xhr.readyState == 4){
            if(xhr.status == 200){
                //实际操作
                result.innerHTML += xhr.responseText;
            }
        }
    }
    //发送请求
    xhr.open(&#39;get&#39;,&#39;message.xml&#39;,true);
    xhr.send();
}
</script>
Nach dem Login kopieren
Verständnis von XHR-Objekten in Ajax-Serien
//message.xml
<p>hello world</p>
Nach dem Login kopieren
Nach dem Login kopieren

 

超时

  XHR对象的timeout属性等于一个整数,表示多少毫秒后,如果请求仍然没有得到结果,就会自动终止。该属性默认等于0,表示没有时间限制

  如果请求超时,将触发ontimeout事件

  [注意]IE8-浏览器不支持该属性

Verständnis von XHR-Objekten in Ajax-Serien
xhr.open('post','test.php',true);
xhr.ontimeout = function(){
    console.log('The request timed out.');
}
xhr.timeout = 1000;
xhr.send();
Nach dem Login kopieren
Verständnis von XHR-Objekten in Ajax-Serien

 

优化

  使用AJAX接收数据时,由于网络和数据大小的原因,并不是立刻就可以在页面中显示出来。所以,更好的做法是,在接受数据的过程中,显示一个类似loading的小图片,并且禁用按钮;当数据完全接收后,再隐藏该图片,并启用按钮

Verständnis von XHR-Objekten in Ajax-Serien
<button>获取信息</button>
<img  src="/static/imghw/default1.png" data-src="" class="lazy" alt="Verständnis von XHR-Objekten in Ajax-Serien" >
<div></div>
<script>
var add = (function(){
    var counter = 0;
    return function(){
        return ++counter;
    }
})();
btn.onclick = function(){
    img.style.display = &#39;inline-block&#39;;
    btn.setAttribute(&#39;disabled&#39;,&#39;&#39;);
    //创建xhr对象
    var xhr;
    if(window.XMLHttpRequest){
        xhr = new XMLHttpRequest();
    }else{
        xhr = new ActiveXObject(&#39;Microsoft.XMLHTTP&#39;);
    }
    //异步接受响应
    xhr.onreadystatechange = function(){
        if(xhr.readyState == 4){
            if(xhr.status == 200){
              img.style.display = &#39;none&#39;;
              btn.removeAttribute(&#39;disabled&#39;);
              var data = JSON.parse(xhr.responseText);
              var sum = add() - 1;
              if(sum < data.length){
                result.innerHTML += data[sum];    
              }
            }
        }
    }
    //发送请求
    xhr.open(&#39;get&#39;,&#39;data.php&#39;,true);
    xhr.send();
}
</script>
Nach dem Login kopieren
Verständnis von XHR-Objekten in Ajax-Serien
<?php echo json_encode([1,2,3,4,5]);
?>
Nach dem Login kopieren

Endlich

Durch die Demonstration von Beispielen haben wir festgestellt, dass der Inhalt des Ajax-Frontends selbst nicht schwierig ist. Da Ajax jedoch einige Back-End- und Netzwerkkenntnisse erfordert, ist es nicht einfach zu erlernen. Zukünftige Blog-Beiträge werden nach und nach die wichtigsten Inhalte von Ajax ausführlich vorstellen

Das obige ist der detaillierte Inhalt vonVerständnis von XHR-Objekten in Ajax-Serien. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So beheben Sie den 403-Fehler, der bei einer jQuery-AJAX-Anfrage auftritt So beheben Sie den 403-Fehler, der bei einer jQuery-AJAX-Anfrage auftritt Feb 20, 2024 am 10:07 AM

Titel: Methoden und Codebeispiele zur Behebung von 403-Fehlern in jQuery-AJAX-Anfragen. Der 403-Fehler bezieht sich auf eine Anfrage, dass der Server den Zugriff auf eine Ressource verbietet. Dieser Fehler tritt normalerweise auf, weil der Anfrage die Berechtigungen fehlen oder sie vom Server abgelehnt wird. Wenn Sie jQueryAJAX-Anfragen stellen, stoßen Sie manchmal auf diese Situation. In diesem Artikel wird erläutert, wie dieses Problem gelöst werden kann, und es werden Codebeispiele bereitgestellt. Lösung: Berechtigungen prüfen: Stellen Sie zunächst sicher, dass die angeforderte URL-Adresse korrekt ist und stellen Sie sicher, dass Sie über ausreichende Berechtigungen für den Zugriff auf die Ressource verfügen.

So beheben Sie den Fehler 403 der jQuery AJAX-Anfrage So beheben Sie den Fehler 403 der jQuery AJAX-Anfrage Feb 19, 2024 pm 05:55 PM

jQuery ist eine beliebte JavaScript-Bibliothek zur Vereinfachung der clientseitigen Entwicklung. AJAX ist eine Technologie, die asynchrone Anfragen sendet und mit dem Server interagiert, ohne die gesamte Webseite neu zu laden. Wenn Sie jedoch jQuery zum Senden von AJAX-Anfragen verwenden, treten manchmal 403-Fehler auf. Bei 403-Fehlern handelt es sich in der Regel um vom Server verweigerte Zugriffsfehler, möglicherweise aufgrund von Sicherheitsrichtlinien oder Berechtigungsproblemen. In diesem Artikel besprechen wir, wie Sie bei einer jQueryAJAX-Anfrage den Fehler 403 beheben können

Wie erhalte ich Variablen aus der PHP-Methode mit Ajax? Wie erhalte ich Variablen aus der PHP-Methode mit Ajax? Mar 09, 2024 pm 05:36 PM

Die Verwendung von Ajax zum Abrufen von Variablen aus PHP-Methoden ist ein häufiges Szenario in der Webentwicklung. Durch Ajax kann die Seite dynamisch abgerufen werden, ohne dass die Daten aktualisiert werden müssen. In diesem Artikel stellen wir vor, wie man Ajax verwendet, um Variablen aus PHP-Methoden abzurufen, und stellen spezifische Codebeispiele bereit. Zuerst müssen wir eine PHP-Datei schreiben, um die Ajax-Anfrage zu verarbeiten und die erforderlichen Variablen zurückzugeben. Hier ist ein Beispielcode für eine einfache PHP-Datei getData.php:

Wie kann das Problem des jQuery AJAX-Fehlers 403 gelöst werden? Wie kann das Problem des jQuery AJAX-Fehlers 403 gelöst werden? Feb 23, 2024 pm 04:27 PM

Wie kann das Problem des jQueryAJAX-Fehlers 403 gelöst werden? Bei der Entwicklung von Webanwendungen wird jQuery häufig zum Senden asynchroner Anfragen verwendet. Allerdings kann bei der Verwendung von jQueryAJAX manchmal der Fehlercode 403 auftreten, der darauf hinweist, dass der Zugriff vom Server verboten ist. Dies wird normalerweise durch serverseitige Sicherheitseinstellungen verursacht, es gibt jedoch Möglichkeiten, das Problem zu beheben. In diesem Artikel wird erläutert, wie Sie das Problem des jQueryAJAX-Fehlers 403 lösen können, und es werden spezifische Codebeispiele bereitgestellt. 1. machen

PHP und Ajax: Erstellen einer Autovervollständigungs-Vorschlags-Engine PHP und Ajax: Erstellen einer Autovervollständigungs-Vorschlags-Engine Jun 02, 2024 pm 08:39 PM

Erstellen Sie eine Engine für Autovervollständigungsvorschläge mit PHP und Ajax: Serverseitiges Skript: Verarbeitet Ajax-Anfragen und gibt Vorschläge zurück (autocomplete.php). Client-Skript: Ajax-Anfrage senden und Vorschläge anzeigen (autocomplete.js). Praktischer Fall: Fügen Sie ein Skript in die HTML-Seite ein und geben Sie die Kennung des Sucheingabeelements an.

PHP vs. Ajax: Lösungen zum Erstellen dynamisch geladener Inhalte PHP vs. Ajax: Lösungen zum Erstellen dynamisch geladener Inhalte Jun 06, 2024 pm 01:12 PM

Ajax (Asynchronous JavaScript and XML) ermöglicht das Hinzufügen dynamischer Inhalte, ohne die Seite neu laden zu müssen. Mit PHP und Ajax können Sie eine Produktliste dynamisch laden: HTML erstellt eine Seite mit einem Containerelement und die Ajax-Anfrage fügt die Daten nach dem Laden zum Element hinzu. JavaScript verwendet Ajax, um über XMLHttpRequest eine Anfrage an den Server zu senden, um Produktdaten im JSON-Format vom Server abzurufen. PHP nutzt MySQL, um Produktdaten aus der Datenbank abzufragen und in das JSON-Format zu kodieren. JavaScript analysiert die JSON-Daten und zeigt sie im Seitencontainer an. Durch Klicken auf die Schaltfläche wird eine Ajax-Anfrage zum Laden der Produktliste ausgelöst.

Asynchroner Datenaustausch mithilfe von Ajax-Funktionen Asynchroner Datenaustausch mithilfe von Ajax-Funktionen Jan 26, 2024 am 09:41 AM

So verwenden Sie Ajax-Funktionen, um eine asynchrone Dateninteraktion zu erreichen. Mit der Entwicklung der Internet- und Webtechnologie ist die Dateninteraktion zwischen dem Front-End und dem Back-End sehr wichtig geworden. Herkömmliche Dateninteraktionsmethoden wie Seitenaktualisierung und Formularübermittlung können die Benutzeranforderungen nicht mehr erfüllen. Ajax (Asynchronous JavaScript and XML) ist zu einem wichtigen Werkzeug für die asynchrone Dateninteraktion geworden. Ajax ermöglicht dem Web die Verwendung von JavaScript und dem XMLHttpRequest-Objekt

PHP und Ajax: Möglichkeiten zur Verbesserung der Ajax-Sicherheit PHP und Ajax: Möglichkeiten zur Verbesserung der Ajax-Sicherheit Jun 01, 2024 am 09:34 AM

Um die Ajax-Sicherheit zu verbessern, gibt es mehrere Methoden: CSRF-Schutz: Generieren Sie ein Token und senden Sie es an den Client. Fügen Sie es der Serverseite in der Anforderung zur Überprüfung hinzu. XSS-Schutz: Verwenden Sie htmlspecialchars(), um Eingaben zu filtern und das Einschleusen böswilliger Skripte zu verhindern. Content-Security-Policy-Header: Beschränken Sie das Laden schädlicher Ressourcen und geben Sie die Quellen an, aus denen Skripte und Stylesheets geladen werden dürfen. Validieren Sie serverseitige Eingaben: Validieren Sie von Ajax-Anfragen empfangene Eingaben, um zu verhindern, dass Angreifer Eingabeschwachstellen ausnutzen. Verwenden Sie sichere Ajax-Bibliotheken: Profitieren Sie von automatischen CSRF-Schutzmodulen, die von Bibliotheken wie jQuery bereitgestellt werden.

See all articles