En esta ocasión y tras mucho tiempo, os traigo un artículo breve para explicar cómo solucionar un bug o error que existe en Safari, concretamente en la versión del mismo para iOS 6 y iOS 7.

Estoy preparando, entre otras cosas, mi página web para el 2015 (espero tenerla antes) y he hecho alguna cosilla chula utilizando los vh (viewport height o unidad relativa a la altura visible del navegador).

El caso es que he utilizado Firefox para maquetar el nuevo diseño y al probarlo en otros navegadores ha funcionado perfecto. El problema ha llegado al probar iOS 7, donde la unidad vh no respondía según lo esperado.

Teóricamente (y digo teóricamente porque es lo que he leído buscando sobre el error), es un bug relacionado con el manejo de la pantalla retina en iOS 6 y 7.

La solución

Para solucionarlo, os dejo un trozo de código que podéis pegar en vuestro fichero de javascript (o meterlo como script) que convierte las unidades viewport a píxeles haciendo un cálculo sencillo:

/* Fix iOS 7 bug for -unit support */
var iOS = navigator.userAgent.match(/(iPod|iPhone|iPad)/);
if(iOS){
    function iosVhHeightBug() {
        var height = $(window).height();
        $("#capa-para-redimensionar").css('min-height', height);
    }
 
    iosVhHeightBug();
    $(window).bind('resize', iosVhHeightBug);
}

Como siempre, dar las gracias a la fuente por compartir conocimiento.