Home  >  Article  >  Web Front-end  >  How can I track the progress of XMLHttpRequest operations, especially for large file uploads and downloads?

How can I track the progress of XMLHttpRequest operations, especially for large file uploads and downloads?

Barbara Streisand
Barbara StreisandOriginal
2024-10-28 02:05:30445browse

How can I track the progress of XMLHttpRequest operations, especially for large file uploads and downloads?

Monitoring XMLHttpRequest Progress: A Comprehensive Guide

The standard XMLHttpRequest (XHR) API lacks built-in support for progress tracking, impeding efforts to display progress bars during large file uploads. However, numerous browsers offer non-standard extensions that enable progress monitoring.

Bytes Uploaded

To monitor the progress of bytes uploaded, utilize the xhr.upload.onprogress event. The browser knows both the size of the file being uploaded and the amount of data already transmitted, making it possible to determine the upload progress.

Bytes Downloaded

Determining the progress of bytes downloaded (when using xhr.responseText) is more complex because the browser has no prior knowledge of the total size of the data being transferred. One solution is to set a Content-Length header in the server script to specify the total byte size expected.

For instance, if our server script reads a 5-second ZIP file, we can set the header as follows:

<code class="php">$filesize = filesize('test.zip');
header("Content-Length: " . $filesize); // Set header length
readfile('test.zip');
exit 0;</code>

By setting the header, the browser can determine the total length of the response and monitor the received bytes accordingly.

Event Monitoring

To monitor the progress of both uploads and downloads, use the following event listeners:

<code class="javascript">// Event listener for upload progress
xhr.upload.onprogress = function(evt) {
  if (evt.lengthComputable) {
    var uploadPercentage = (evt.loaded / evt.total) * 100;
    // Update progress bar or display percentage
  }
};

// Event listener for download progress
xhr.onprogress = function(evt) {
  if (evt.lengthComputable) {
    var downloadPercentage = (evt.loaded / evt.total) * 100;
    // Update progress bar or display percentage
  }
};</code>

Example

This example demonstrates progress monitoring during a file download using jQuery UI's progress bar:

<code class="javascript">function updateProgress(evt) {
  if (evt.lengthComputable) {
    var percentComplete = (evt.loaded / evt.total) * 100;
    $('#progressbar').progressbar("option", "value", percentComplete);
  }
}

function sendRequest() {
  var req = new XMLHttpRequest();
  $('#progressbar').progressbar();
  req.onprogress = updateProgress;
  req.onloadstart = function() {
    updateProgress({ loaded: 0, total: 0 });
  };
  req.open('GET', 'test.php', true);
  req.send();
}

// Sending the request
sendRequest();</code>

By incorporating these techniques, you can effectively monitor the progress of XMLHttpRequest operations, enabling a more user-friendly experience during large file transfers.

The above is the detailed content of How can I track the progress of XMLHttpRequest operations, especially for large file uploads and downloads?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn