|
| 1 | +# Responsive iframes |
| 2 | + |
| 3 | +## Problem description |
| 4 | + |
| 5 | +[Iframes]([url](https://developer.mozilla.org/en-US/docs/Web/HTML/Reference/Elements/iframe)) are very useful for sandboxing web content into different documents. The options currently available are: |
| 6 | + 1. A [same-origin]([url](https://developer.mozilla.org/en-US/docs/Web/Security/Same-origin_policy)) iframe, which provides full style & |
| 7 | +layout isolation, and by-default script isolation. This prevents the parent and child documents from accidentally interfering with each other. |
| 8 | + 2. A cross-origin iframe, which additionally provides robust security against untrusted embedders or embedees. |
| 9 | + |
| 10 | +In addition, iframes participate in the layout of the parent document, via the style and layout of their owning `` element. |
| 11 | +However, unlike other HTML elements such as ``, iframe elements do not have the ability to support *responsive layout*, i.e. size themselves automatically to contain the [natural dimensions]([url](https://drafts.csswg.org/css-images-3/#natural-dimensions)) of the contents of the iframe. Instead, browser automatically add scrollbars to ifrmaes as necessary, so that users can access the content. |
| 12 | + |
| 13 | +This is a problem: |
| 14 | + * From a user's perspective, iframe scrollbars are a worse UX in cases where the iframe contents are important to them and can fit reasonably in the visible viewport without these additional scrollbars. |
| 15 | + * From a developer's perspective, they are forced to use script to communicate natural dimensions, in order to help the user have better UX without scrollbars. |
| 16 | + |
| 17 | +Embedded SVG documents already support responsive layout. *Responsive iframes* add responsive layout to iframes, as long as the embedding and embedded document both opt into do so. This allows supporting responsive layout without losing any of the advantages of iframes in (1) and (2) above. |
| 18 | + |
| 19 | +## Use cases |
| 20 | + |
| 21 | +Use cases include: |
| 22 | + * 3P comment widgets ([example]([url](https://github.com/whatwg/html/issues/555#issuecomment-177836009))) |
| 23 | + * Embedding self-contained worked examples in teaching UI ([example]([url](https://browser.engineering/layout.html))). |
| 24 | + |
| 25 | +In general, there is a lot of demand for this feature, as evidenced by: |
| 26 | + * [Stack overflow]([url](https://stackoverflow.com/search?q=resize+iframe)) |
| 27 | + * Many comments and positive reactions on the [issue proposing the feature for HTML]([url](https://github.com/whatwg/html/issues/555)), and [the same for CSS]([url](https://github.com/w3c/csswg-drafts/issues/1771)). |
| 28 | + * Existence of multiple polyfills |
| 29 | + |
| 30 | +## Solution |
| 31 | + |
| 32 | + |
| 33 | +The embedding document does so via the `contain-intrinsic-size: from-element` CSS property on the `` element, and the embedded document via a new `` tag with name `responsive-embedded-sizing`. |
| 34 | + |
| 35 | +When both are set, then at the time the `load` event on the embedded document fires, the embedding document is notified with the new [natural height]([url](https://drafts.csswg.org/css-images-3/#natural-height)) of the embedded (iframe) document. This height is then taken into account in the final size of the `` element, along with other constraints specified by the HTML and CSS of the embedding document. Subsequent changes to content, styling or layout fo the embedded document do not affect the `` sizing. |
| 36 | + |
| 37 | +The double opt-in preserves: |
| 38 | + * Backward compatibility for existing content. |
| 39 | + * Privacy and security guarantees of cross-origin content. |
| 40 | + |
| 41 | +The "one-shot" sizing to natural dimensions avoids: |
| 42 | + * Performance issues and CLS due to changing iframe sizing. (To further mitigatge performance risks, limitations on levels of `` nesting may be imposed.) |
| 43 | + * Potential infinite layout loops. |
| 44 | + |
| 45 | +## Future extensions |
| 46 | + |
| 47 | +A JavaScript API could be added in the future that would allow embedded documents to request relayout in their embedding document context. |
| 48 | + |
| 49 | +## Privacy and security |
| 50 | + |
| 51 | +Information about the contents of a cross-origin iframe can be exfiltrated by an embedding malicious document that observes the laid-out size of the iframe. This can be mitigated through use of the the `X-Frame-Options` HTTP header to allow embedding into only trusted embedding documents, plus the `responsive-embedded-sizing` `` tag to further opt into responsive layout. Additional restrictions could be put in place through contents of the `` tag that would restrict to only explicitly allowed origins. |
0 commit comments