search

Home  >  Q&A  >  body text

How to hide all IFrames in an HTML page if the IFrame source has XML errors?

I'm having trouble trying to display a PDF preview within an iframe tag. I have a page that contains some iframes to display a PDF file in the page, the problem is sometimes the PDF is not present in the source URL, so the iframe shows an XML error stating BlobNotFound. I want to hide iframe if that error is returned in the source code of iframe.

I tried the following JavaScript script:

<script>
  const myIframe = document.getElementById('myFrame1');
  fetch('example.xml')
      .then(response => {
          if (!response.ok) {
              throw new Error('XML file not found');
          }
          return response.text();
      })
      .then(xmlString => {
          const parser = new DOMParser();
          const xmlDoc = parser.parseFromString(xmlString, "text/xml");
          // check for errors in the XML content
          const error = xmlDoc.getElementsByTagName("parsererror");
          if (error.length > 0) {
              myIframe.style.display = 'none'; // hide the iframe if there is an error
          }
      })
      .catch(error => {
          console.error(error);
          myIframe.style.display = 'none'; // hide the iframe if there is an error
      });
</script>

This code works, but only if you specify the iframe tag by ID, and I want to rewrite this code to check all iframe at once.

I also tried the following code:

<script>
  const iframes = document.getElementsByTagName('iframe');
  for (let i = 0; i < iframes.length; i++) {
      const iframe = iframes[i];
      fetch(iframe.src)
          .then(response => {
              if (!response.ok) {
                  throw new Error('XML file not found');
              }
              return response.text();
          })
          .then(xmlString => {
              const parser = new DOMParser();
              const xmlDoc = parser.parseFromString(xmlString, "text/xml");
              // check for errors in the XML content
              const error = xmlDoc.getElementsByTagName("parsererror");
              if (error.length > 0) {
                  iframe.style.display = 'none'; // hide the iframe if there is an error
              }
          })
          .catch(error => {
              console.error(error);
              iframe.style.display = 'none'; // hide the iframe if there is an error
          });
  }
</script>

This code should work, but somehow it hides all iframes even though it has no errors.

P.S.\ This is an XML error for any iframe that cannot display the PDF.

<?xml version="1.0" encoding="utf-8"?>
<Error>
    <Code>BlobNotFound</Code>
    <Message>
        The specified blob does not exist.
            RequestId:xxxxxxxx
            Time:timestamp
    </Message>
</Error>

P粉308089080P粉308089080364 days ago438

reply all(1)I'll reply

  • P粉043295337

    P粉0432953372024-01-11 12:50:34

    You can try this!

    <!DOCTYPE html>
    <html>
    <head>
      <title>Hide Iframes with XML Error</title>
    </head>
    <body>
      <iframe src="path/to/pdf1.pdf"></iframe>
      <iframe src="path/to/pdf2.pdf"></iframe>
      <iframe src="path/to/nonexistent.pdf"></iframe>
      <iframe src="path/to/pdf3.pdf"></iframe>
      <script>
        var iframes = document.getElementsByTagName('iframe');
        for (var i = 0; i < iframes.length; i++) {
          var iframe = iframes[i];
          iframe.contentWindow.addEventListener('error', function(event) {
            if (event.message === 'BlobNotFound') {
              // Hide all iframes if any one of them has an XML error
              for (var j = 0; j < iframes.length; j++) {
                iframes[j].style.display = 'none';
              }
            }
          });
        }
      </script>
    </body>
    </html>

    Please tell me if it works.

    reply
    0
  • Cancelreply