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;
 }

Démonstration

Les commentaires sont fermés.