html - sintomas - reflujo gastroesofagico tratamiento
Ajuste el ancho/alto de la imagen para evitar el reflujo en la carga de la imagen (5)
Al principio, me gustaría escribir sobre la respuesta de octubre de 2013. Esto se copió de forma incompleta y, debido a esto, no es correcto. No lo uses. ¿Por qué? Podemos verlo en este fragmento (desplaza el fragmento ejecutado hacia abajo):
$(''img'').each(function() {
var aspect_ratio = $(this).attr(''height'') / $(this).attr(''width'') * 100;
$(this).wrap(''<div style="padding-bottom: '' + aspect_ratio + ''%">'');
});
img { max-width: 100%; height: auto; }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div style="width:300px;border:1px solid red">
<img width="400" height="300" src=""/>
Some text
</div>
Y podemos ver que el texto está lejos desde abajo . ¿Qué hay en este ejemplo incompleto / incorrecto? Lo mostraré con el ejemplo correcto con JavaScript puro (no necesitamos descargar jQuery para eso).
Ejemplo correcto con JavaScript puro
Por favor, desplace el fragmento ejecutado a la parte inferior.
var imgs = document.querySelectorAll(''img'');
for(var i = 0; i < imgs.length; i++)
{
var aspectRatio = imgs[i].getAttribute(''height'') /
imgs[i].getAttribute(''width'') * 100;
var div = document.createElement(''div'');
div.style.paddingBottom = aspectRatio + ''%'';
imgs[i].parentNode.insertBefore(div, imgs[i]);
div.appendChild(imgs[i]);
}
.restrict-container div{position:relative}
img
{
position:absolute;
max-width:100%;
top:0; left:0;
height:auto
}
<div class="restrict-container" style="width:300px;border:1px solid red">
<img width="400" height="300" src=""/>
Some text<br>
<img width="400" height="300" src=""/>
Some text
</div>
El error de la respuesta de octubre de 2013: la imagen debe colocarse absoluta ( position:absolute
) en el contenedor envuelto, pero no está colocada.
Este es el final de mi respuesta a esta pregunta.
Para más información lea más sobre :
- ¿Qué podríamos hacer con la nueva tecnología HTML5 para obtener imágenes receptivas también? (Esta es la versión extendida anterior de mi publicación aquí. Vea la segunda parte).
Cuando utilizo etiquetas de imagen en html, trato de especificar su ancho y alto en la etiqueta img
, para que el navegador les reserve espacio incluso antes de que se carguen las imágenes, de modo que cuando terminen de cargarse, la página no vuelva a fluir ( Los elementos no se mueven alrededor. Por ejemplo:
<img width="600" height="400" src="..."/>
El problema ahora es que quiero crear una versión más "responsiva", donde para el "caso de una sola columna" me gustaría hacer esto:
<img style="max-width: 100%" src="..."/>
pero, si mezclo esto con el ancho y alto explícitamente especificados, como:
<img style="max-width: 100%" width="600" height="400" src="..."/>
y la imagen es más ancha que el espacio disponible, entonces la imagen se redimensiona ignorando la relación de aspecto. Entiendo por qué sucede esto (porque "arreglé" la altura de la imagen), y me gustaría arreglarlo, pero no tengo idea de cómo hacerlo.
Para resumir: quiero poder especificar max-width: 100%
, y también de alguna manera asegurarme de que el contenido no se refleje cuando se carguen las imágenes.
De esta publicación de blog de Jonathan Hollin : agregue la altura y el ancho de la imagen como parte de un estilo en línea. Esto reserva espacio para la imagen, evitando el reflujo cuando se carga la imagen, pero también responde.
HTML
<figure style="padding-bottom: calc((400/600)*100%)">
<img src="/images/kitten.jpg" />
</figure>
CSS
figure {
position: relative;
}
img {
max-width: 100%;
position: absolute;
}
La figure
se puede reemplazar por un div
o cualquier otro contenedor de su elección. Esta solución se basa en CSS calc () que tiene un soporte de navegador bastante amplio .
Codepen trabajando se puede ver here .
ACTUALIZAR:
Encontré una versión alternativa mucho más inteligente de esto: http://cssmojo.com/aspect-ratio-using-custom-properties-and-calc/ . Esto todavía requiere un elemento envoltorio y requiere propiedades personalizadas de CSS, pero creo que es mucho más elegante. El ejemplo de Codepen está here (crédito del original Chris Coyier).
Para una solución solo para CSS, puede envolver el img
en un contenedor donde el porcentaje de padding-bottom
espacio padding-bottom
reserva espacio en la página hasta que se cargue la imagen, lo que evita el reflujo.
Desafortunadamente, este enfoque requiere que incluya la relación de aspecto de la imagen en su css (pero no es necesario para los estilos en línea) calculando (o permitiendo que css calcule para usted) el porcentaje del padding-bottom
basado en la altura y el ancho de la imagen.
Si muchas de sus imágenes se pueden agrupar en unas pocas relaciones de aspecto estándar, entonces podría crear una clase para cada relación de aspecto para aplicar el porcentaje de padding-bottom
apropiado a todas las imágenes con esa relación de aspecto. Esto puede ahorrarle un poco de tiempo y esfuerzo si no está tratando con una amplia variedad de relaciones de aspecto de imagen.
A continuación se muestran algunos ejemplos de html y css para una imagen con una relación de aspecto de 2: 1:
HTML
<div class="container">
<img id="image" src="https://via.placeholder.com/300x150" />
</div>
CSS
.container {
display: block;
position: relative;
padding-bottom: 50%; /* calc(100%/(300/150)); */
height: 0;
}
.container img {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
El fragmento a continuación agrega algunos html, css y javascript adicionales para crear algunos puntos de referencia superior e inferior visuales e imitar una imagen de carga muy lenta para que pueda ver visualmente cómo se evita el reflujo con este enfoque.
const image = document.getElementById(''image'');
const source = ''https://via.placeholder.com/300x150'';
const changeSource = () => image.src = source;
setTimeout(changeSource, 3000);
.container {
display: block;
position: relative;
padding-bottom: 50%; /* calc(100%/(300/150)); */
height: 0;
}
.container img {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
.top, .bottom {
background-color: green;
width: 100%;
height: 20px;
}
<div class="top"></div>
<div class="container">
<img id="image" src="" />
</div>
<div class="bottom"></div>
Si entiendo bien los requisitos, desea poder establecer un tamaño de imagen, donde este tamaño se conoce solo en la generación de contenido (HTML), por lo que se puede establecer como estilos en línea.
Pero esto tiene que ser independiente del CSS, y también antes de cargar la imagen, por lo que también debe ser independiente de los tamaños de esta imagen.
He llegado a una solución que involucra envolver la imagen en un div, e incluir en este div un svg que se puede configurar para tener proporciones directamente como un estilo en línea.
Obviamente esto no es mucho semántico , pero al menos funciona.
El div que contiene tiene una clase llamada img para mostrar que, bueno, debería ser un img
Para intentar reproducir la etapa de carga, las imágenes tienen un src roto.
.container {
margin: 10px;
border: solid 1px black;
width: 200px;
height: 400px;
position: relative;
}
.img {
border: solid 1px red;
width: fit-content;
max-width: 100%;
position: relative;
}
svg {
max-width: 100%;
background-color: lightgreen;
opacity: 0.1;
}
#ct2 {
width: 500px;
}
.img img {
position: absolute;
width: 100%;
height: 100%;
max-height: 100%;
max-width: 100%;
top: 0px;
left: 0px;
box-shadow: inset 0px 0px 10px blue;
}
<div class="container" id="ct1">
<div class="img">
<svg xmlns="http://www.w3.org/2000/svg" preserveAspectRatio="xMinYMin meet" viewBox="0 0 400 300" width="400">
</svg>
<img width="400" height="300" src="missing.jpg">
</div>
</div>
<div class="container" id="ct2">
<div class="img">
<svg xmlns="http://www.w3.org/2000/svg" preserveAspectRatio="xMinYMin meet" viewBox="0 0 40 30" width="400">
</svg>
<img width="400" height="300" src="missing.jpg">
</div>
</div>
También estoy buscando la respuesta a este problema. Con max-width
, width=
y height=
, el navegador tiene suficientes datos para poder dejar la cantidad correcta de espacio para una imagen, pero parece que no funciona de esa manera.
Trabajé alrededor de esto con una solución jQuery por ahora. Requiere que proporcione el width=
y la height=
para sus etiquetas <img>
.
CSS:
img { max-width: 100%; height: auto; }
HTML:
<img src="image.png" width="400" height="300" />
jQuery:
$(''img'').each(function() {
var aspect_ratio = $(this).attr(''height'') / $(this).attr(''width'') * 100;
$(this).wrap(''<div style="padding-bottom: '' + aspect_ratio + ''%">'');
});
Esto aplica automáticamente la técnica que se ve en: http://andmag.se/2012/10/responsive-images-how-to-prevent-reflow/