


Why Doesn\'t z-index Work with PDFs in iFrames in Internet Explorer?
z-index Doesn't Work in IE with PDF in an iFrame
In Internet Explorer (IE), attempting to utilize z-index on an iFrame containing a PDF may result in unexpected behavior. Despite working seamlessly in other browsers like Chrome, IE users encounter difficulties.
To understand this issue, we need to delve into the concept of "windowed" and "windowless" elements in IE. Windowed elements, such as ActiveX controls and select dropdowns, are rendered outside of the browser's main MSHTML plane. In contrast, windowless elements, like divs and input fields, are rendered within this plane.
Windowed vs. Windowless Element Interactions
Crucially, windowed elements always take precedence over windowless elements, regardless of z-index. This is where the problem with iFrames containing PDFs arises. In IE, PDFs are treated as windowed elements, meaning they will always appear on top of windowless elements, even if the latter have a higher z-index.
The Solution: A Fix Using Another iFrame
Unfortunately, there is no straightforward fix to this issue. However, a workaround can be achieved by introducing another iFrame between the PDF and the page content. This "cover" iFrame has a negative z-index, ensuring that it remains hidden from view. By blocking the overflow of the PDF, it allows normal z-index behavior to apply to the main page content, allowing text or other elements to appear on top of the PDF.
Implementation Details
The following code outlines the solution:
HTML:
<code class="html"><div id="outer"> <div id="inner">my text that should be on top</div> <iframe class="cover" src="about:blank"></iframe> </div> <iframe id="pdf" src="http://legallo1.free.fr/french/CV_JLG.pdf" width="200" height="200"></iframe></code>
CSS:
<code class="css">#outer { position: relative; left: 150px; top: 20px; width: 100px; z-index: 2; } #inner { background: red; } .cover { border: none; position: absolute; top: 0; left: 0; height: 100%; width: 100%; z-index: -1; } #pdf { position: relative; z-index: 1; }</code>
Conclusion
By utilizing another iFrame with a negative z-index, we effectively create a barrier between the PDF and the page content. This workaround allows for expected z-index behavior, enabling text or other elements to appear on top of the PDF in IE. While this solution is not ideal, it provides a means to address the z-index issue in IE.
The above is the detailed content of Why Doesn\'t z-index Work with PDFs in iFrames in Internet Explorer?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



The Svelte transition API provides a way to animate components when they enter or leave the document, including custom Svelte transitions.

If you’ve recently started working with GraphQL, or reviewed its pros and cons, you’ve no doubt heard things like “GraphQL doesn’t support caching” or

How much time do you spend designing the content presentation for your websites? When you write a new blog post or create a new page, are you thinking about

With the recent climb of Bitcoin’s price over 20k $USD, and to it recently breaking 30k, I thought it’s worth taking a deep dive back into creating Ethereum

No matter what stage you’re at as a developer, the tasks we complete—whether big or small—make a huge impact in our personal and professional growth.

I'd say "website" fits better than "mobile app" but I like this framing from Max Lynch:

It's out! Congrats to the Vue team for getting it done, I know it was a massive effort and a long time coming. All new docs, as well.

npm commands run various tasks for you, either as a one-off or a continuously running process for things like starting a server or compiling code.
