If you need an aspect-ratio sized
But media elements like
don’t have children. The
tag isn’t self-closing, but when it is supported (almost always), the content of it is replaced with a shadow DOM you don’t control. Besides, these are the only two elements that « size to an external resource. » So, how do you enforce aspect ratio on them when using a variable width like
75vw? Well, once they load, they will have their natural aspect ratio, so that’s nice. But it also means they don’t know the height while they are loading and it may cause performance jank-ening reflow.
One solution is to put them into a container with an aspect ratio, forcing them to the corners with absolute positioning. But, all by themselves, they are incapable of sizing to the aspect ratio correctly until they load.
intrinsicsize attribute for « all image element types (including SVG images) and videos » that is now under development.
The explainer document is helpful. The reason it is
intrinsicsize and not
aspectratio is because an aspect ratio doesn’t provide as much useful or usable information. I’d love to see it work on any element and be brought to CSS as well.