Heim >Web-Frontend >js-Tutorial >Wie kann ich den Fortschritt der Datenübertragung in XMLHttpRequest verfolgen?

Wie kann ich den Fortschritt der Datenübertragung in XMLHttpRequest verfolgen?

Patricia Arquette
Patricia ArquetteOriginal
2024-10-29 10:02:02429Durchsuche

How Can I Track the Progress of Data Transfer in XMLHttpRequest?

Überwachung des Fortschritts in XMLHttpRequest

XMLHttpRequest ermöglicht Webanwendungen das asynchrone Senden und Empfangen von Daten. Ist es möglich, den Fortschritt einer XMLHttpRequest zu verfolgen, insbesondere die hochgeladenen und heruntergeladenen Bytes?

Hochgeladene Bytes

Das Abrufen des Fortschritts der hochgeladenen Bytes ist relativ einfach. Nutzen Sie das Ereignis xhr.upload.onprogress. Der Browser berechnet den Fortschritt, indem er die Größe der hochgeladenen Daten mit der Gesamtdateigröße vergleicht.

Heruntergeladene Bytes

Die Überwachung des Fortschritts der heruntergeladenen Bytes ist für den Browser normalerweise schwieriger kennt die Gesamtantwortgröße nicht. Eine Problemumgehung besteht darin, den Content-Length-Header im serverseitigen Skript festzulegen, um die Gesamtantwortgröße anzugeben. Dadurch kann der Browser den Download-Fortschritt berechnen.

Beispiel

Stellen Sie sich ein Serverskript vor, das eine ZIP-Datei mit bekannter Größe liest und sendet:

<?php
$filesize = filesize('test.zip');
header("Content-Length: " . $filesize);
readfile('test.zip');
?>

Der folgende JavaScript-Code kann dann den Download-Fortschritt mithilfe des Content-Length-Headers überwachen:

<code class="javascript">function updateProgress(evt) {
   if (evt.lengthComputable) {
      // evt.loaded: Bytes received by the browser
      // evt.total: Total bytes specified in the header
      var percentComplete = (evt.loaded / evt.total) * 100;
      $('#progressbar').progressbar("option", "value", percentComplete);
   }
}   
function sendreq(evt) {
    var req = new XMLHttpRequest(); 
    $('#progressbar').progressbar();    
    req.onprogress = updateProgress;
    req.open('GET', 'test.php', true);  
    req.onreadystatechange = function (aEvt) {  
        if (req.readyState == 4) 
        {  
             //run any callback here
        }  
    };  
    req.send(); 
}</code>

Mit dieser Lösung können Sie den Download-Fortschritt auch für große Dateien überwachen, bei denen der Server nach Updates abgefragt wird nicht ideal.

Das obige ist der detaillierte Inhalt vonWie kann ich den Fortschritt der Datenübertragung in XMLHttpRequest verfolgen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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