Des astuces rapides pour adapter les médias à la taille de leur conteneur dans une approche responsive.
Des images qui s’adaptent à leur conteneur
Une première bonne idée c’est de limiter la taille des images à leur conteneur. Pour cela j’applique le reset responsive de Raphaël Goetter.img { max-width: 100%; height: auto; width: auto; box-sizing: border-box; }Cependant, dans un layout « mobile » avec 1 colonne qui prend toute la largeur, il peut être intéressant de forcer ponctuellement la largeur de certaines images à 100%.
img { width: 100%; }
Pour les vidéos Youtube et les iframes
L’astuce précédente s’applique aussi aux balises <video>. Mais pour les iframes, en particulier les vidéos intégrées depuis Youtube, Dailymotion ou autre, on doit trouver une autre solution. Ma solution préférée vient de cet article de css-tricks Elle consiste à encapsuler l’iframe dans un conteneur <div>Puis à rajouter un padding-bottom en pourcentage à ce conteneur, correspondant au ratio hauteur / largeur de la vidéo; et sortir l’iframe du flux avec un position: absolute
.videoWrapper { position: relative; padding-bottom: 56.25%; /* 16:9 */ height: 0; } .videoWrapper iframe { position: absolute; left: 0; top: 0; width: 100% !important; height: 100% !important; }