2011-07-17 15 views
7

El html es:imagen Fondo CSS sin mostrar en IE7 única

<div class="choose-os"> 
<p> 
    <a href="someLink" class="windows">Microsoft Windows</a> 
    <a href="someOtherLink" class="macos">Apple Mac OS</a> 
</p> 
</div> 

El CSS es:

.choose-os { 
    margin: 20px 0; 
    padding: 20px; 
    background: #e7eefa; 
} 
.choose-os p { 
    margin: 0; 
} 
.choose-os p a { 
    display: inline-block; 
    text-indent: -100000px; 
    height: 56px; 
    width: 308px; 
} 
.choose-os p a.windows { 
    background: url(../images/button-windows-bg.png) 0 0; 
} 
.choose-os p a.macos { 
    background: url(../images/button-macos-bg.png) 0 0; 
} 
.choose-os p a:hover { 
    background-position: 0 -56px; 
} 

Cualquier sugerencia sería muy apreciada como tener la imagen de fondo también aparecen en IE7.

+0

La página web en vivo es: http://www.landlordmax.com/downloads –

Respuesta

11

El text-indent: -100000px; en combinación con inline-block es lo que causa que los dos elementos no sean visibles en IE7, debido a un error.

Necesita encontrar alguna otra forma de ocultar el texto para IE7 (o no usar inline-block en absoluto, consulte a continuación esta solución más adecuada).

Las opciones incluyen el método en el comentario de @Sotiris, o:

.choose-os p a { 
    display: inline-block; 
    height: 56px; 
    width: 308px; 

    text-indent: -100000px; 

    /* for ie7 */ 
    *text-indent: 0; 
    *font-size: 0; 
    *line-height: 0 
} 

que utiliza el *property: value hackear varias veces para ocultar el texto en IE7.


El problema parece estar relacionado con el uso de display: inline-block.

Por lo tanto, otra solución (que yo prefiero a mi anterior) es:

.choose-os { 
    margin: 20px 0; 
    padding: 20px; 
    background: #e7eefa; 
    overflow: hidden 
} 
.choose-os p a { 
    float: left; 
    margin-right: 4px; 
    text-indent: -100000px; 
    height: 56px; 
    width: 308px; 
} 
+0

Bah, vencerme, +1 :) – andyb

+0

+1 es probable que quiera ocultar el texto, envolverlo con un 'lapso 'y luego' .choose-os span {display: none} 'hará el truco, pero yo no 't saber si 'display: none' afecta a SEO – Sotiris

+0

Acabo de probar ambas soluciones y ninguna de las dos parecía funcionar ... –

-1

IE7 tiene algunas limitaciones serias en CSS. Recomendaría evitar la notación abreviada y declarar explícitamente cada propiedad, luego validar la hoja CSS here.

0

Para mostrar inline-block correctamente en IE7, añadir los siguientes estilos de .choose-os p a

zoom:1 
*display:inline 

(La estrella es importante! Ha ignorado por los navegadores modernos, pero no IE6/7)

IE7 no lo hace Respete el bloque en línea, por lo que debe hacer un poco de magia para que funcione. Hay una gran descripción aquí: http://blog.mozilla.com/webdev/2009/02/20/cross-browser-inline-block/

[editar] Si el texto-guión es también parte del culpable, puede ser mejor de pegarse con display:block y el establecimiento de float:left en sus elementos. Probablemente múltiples rutas válidas para tomar :)

+0

obras 'inline-block' en IE7, siempre que el elemento tenga un estilo predeterminado de 'en línea' (que' a', por supuesto). Este truco solo es necesario si el elemento que está diseñando tiene un estilo predeterminado de 'bloque'. – Spudley

+0

Bastante justo. Flotar en los elementos sigue siendo la mejor solución; 'inline-block' simplemente saltó hacia mí. – Dominic