How to get download progress of an iframe?

Member

by jasen , in category: Javascript , a year ago

How to get download progress of an iframe?

Facebook Twitter LinkedIn Telegram Whatsapp

1 answer

Member

by dana , a year ago

@jasen 

Unfortunately, it is not possible to directly get the download progress of an iframe using JavaScript, as the browser does not expose a built-in API for monitoring iframe download progress.


However, you can implement a workaround by estimating the download progress based on the iframe's loading duration. Here's a step-by-step approach to achieve this:

  1. Wrap your iframe inside a container element:
1
2
3
<div id="iframeContainer">
  <iframe id="myIframe" src="your-iframe-url"></iframe>
</div>


  1. Add a progress bar to visualize the download progress:
1
<div id="progressBar"></div>


  1. Use JavaScript to estimate the download progress:
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
// Get references to elements
const iframeContainer = document.getElementById('iframeContainer');
const myIframe = document.getElementById('myIframe');
const progressBar = document.getElementById('progressBar');

// Function to estimate download progress
function estimateDownloadProgress() {
  const iframeDocument = myIframe.contentDocument || myIframe.contentWindow.document;
  const loadedBytes = iframeDocument.documentElement.innerText.length;
  const totalBytes = myIframe.src.length; // Assuming iframe's src URL length as total size

  const progressPercentage = (loadedBytes / totalBytes) * 100;
  
  // Update progress bar
  progressBar.style.width = progressPercentage + '%';
}

// Add event listener to iframe's load event
myIframe.addEventListener('load', estimateDownloadProgress);


In the code above, we estimate the download progress by comparing the number of loaded bytes with the total size of the iframe's source URL. We assume the length of the src URL as the total size, which is not fully accurate but provides a rough estimation of the progress. Each time the iframe's load event is triggered, the estimateDownloadProgress function is called to update the progress bar based on the estimated progress.


Keep in mind that this workaround is not precise and may not always provide an accurate representation of the actual download progress.

Related Threads:

How to download iframe video with c#?
How to download a file from iframe in javascript?
How to get the duration of a video in iframe?
How to show upload progress percentage in dropzone.js?
How to dynamically change data for progress bar in d3.js?
How to download an xlsx file in React.js?