internet-explorer-9 - descargar - internet explorer 9 windows 7 64 bits
IE9 borde de borde y sangrado de gradiente de fondo (17)
Aquí hay una solución que agrega un degradado de fondo, utilizando un URI de datos para crear una imagen semitransparente que se superpone a cualquier color de fondo. He verificado que se ha recortado correctamente al radio del borde en IE9. Esto es más liviano que las propuestas basadas en SVG pero, como inconveniente, no es independiente de la resolución. Otra ventaja: funciona con su HTML / CSS actual y no requiere envoltura con elementos adicionales.
Tomé un PNG de gradiente aleatorio de 20x20 a través de una búsqueda web y lo convertí en un URI de datos utilizando una herramienta en línea. El URI de datos resultante es más pequeño que el código CSS para todo ese desastre SVG, y mucho menos el SVG en sí. (Puede aplicar esto condicionalmente a IE9 solo con estilos condicionales, clases css específicas del navegador, etc.) Por supuesto, generar un PNG funciona muy bien para gradientes de tamaño de botón, ¡pero no para gradientes de tamaño de página!
HTML:
<span class="button">This is a button</span>
CSS:
span.button {
padding: 5px 10px;
border-radius: 10px;
background-color: orange;
background-image: url();
background-size: 100% 100%;
border: 2px solid white;
color: white;
}
IE9 es aparentemente capaz de manejar esquinas redondeadas utilizando la definición estándar CSS3 de border-radius
de border-radius
.
¿Qué hay del soporte para el radio del borde y el degradado de fondo? Sí, IE9 es apoyarlos a ambos por separado, pero si mezcla los dos, el gradiente sangra fuera de la esquina redondeada.
También veo extrañeza con sombras que se muestran como una línea negra sólida debajo de una caja con esquinas redondeadas.
Aquí están las imágenes que se muestran en IE9:
¿Cómo puedo solucionar este problema?
Creo que vale la pena mencionar que, en muchos casos, puedes usar un recuadro de sombra para "falsificar" el efecto de degradado y evitar los bordes feos en IE9. Esto funciona especialmente bien con los botones.
Vea este ejemplo: http://jsfiddle.net/jancbeck/CJPPW/31/
Decidí desactivar IE9 de redondear esquinas para solucionar este error. Es limpio, fácil de usar y genérico.
{
border-radius:10px;
border-radius:0px /0/;
background:linear-gradient(top , #ffeecc, #ff8800);
/* ... (-moz -ms,-o, -webkit) gradients */
filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0,startColorstr=#ffeecc,endColorstr=#ff8800);
}
Esta publicación del blog me ayudó: http://abouthalf.com/2010/10/25/internet-explorer-9-gradients-with-rounded-corners/
Básicamente, utiliza un comentario condicional para eliminar el filtro y luego crear sprites SVG de gradientes que puede usar como imágenes de fondo.
Sencillo y elegante!
Funciona para mi...
<!--[if gte IE 9]>
<style type="text/css">
.gradient{
filter: ;
}
</style>
css
border-radius: 10px;
background: #00a8db; /* Old browsers */
background: -moz-linear-gradient(top, #00a8db 0%, #116c8c 100%); /* FF3.6+ */
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#00a8db), color- stop(100%,#116c8c)); /* Chrome,Safari4+ */
background: -webkit-linear-gradient(top, #00a8db 0%,#116c8c 100%); /* Chrome10+,Safari5.1+ */
background: -o-linear-gradient(top, #00a8db 0%,#116c8c 100%); /* Opera 11.10+ */
background: -ms-linear-gradient(top, #00a8db 0%,#116c8c 100%); /* IE10+ */
background: linear-gradient(to bottom, #00a8db 0%,#116c8c 100%); /* W3C */
-webkit-box-shadow: 1px 5px 2px #999;
-moz-box-shadow: 1px 1px 5px #999;
box-shadow: 1px 1px 5px #999;
color: #fff;
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr=''#00a8db'', endColorstr=''#116c8c'',GradientType=0 ); /* IE6-8 */
/* IE9 SVG, needs conditional override of ''filter'' to ''none'' */
background: url();
/* W3C Markup, IE10 Release Preview */
background-image: linear-gradient(to top, #116C8C 0%, #00A5D7 100%);
Hay una forma sencilla de hacer que funcione bajo IE9 con solo UN elemento.
Eche un vistazo a este violín: http://jsfiddle.net/bhaBJ/6/
El primer elemento establece el Border-Radius. Segundo pseudo-elemento establece el gradiente de fondo.
Algunas instrucciones clave:
- el padre debe tener una posición relativa o absoluta
- padre debe tener desbordamiento: oculto ; (para que el efecto de radio de borde sea visible)
- :: antes (o :: después) el pseudo-elemento debe tener z-index: -1 (tipo de solución)
La declaración del elemento base es algo así como:
.button{
position: relative;
overflow: hidden; /*make childs not to overflow the parent*/
border-radius: 5px; /*don''t forget to make it cross-browser*/
z-index:2; /*just to be sure*/
}
Declaración de pseudo-elementos:
.button:before{
content: " "; /*make it a node*/
display: block;
position: absolute;
top:0;left:0;bottom:0;right:0; /*same width and height as parent*/
z-index: -1; /*force it to NOT overlay the TEXT node*/
/*GRADIENT declarations...*/
background: -ms-linear-gradient(top, #ff3232 0%,#7db9e8 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr=''#ff3232'',endColorstr=''#7db9e8'',GradientType=0 );
}
IE9 maneja el radio de borde y los gradientes juntos correctamente. El problema es que IE9 hace que el filtro sea apropiado además del gradiente. La forma de resolverlo correctamente es deshabilitar los filtros en las declaraciones de estilo que utilizan la propiedad de filtro.
Como ejemplo de cómo resolver esto mejor:
Tienes una clase de botón en tu hoja de estilo principal.
.btn {
background: linear-gradient(to bottom, #1e5799 0%,#7db9e8 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr=''#1e5799'', endColorstr=''#7db9e8'',GradientType=0 );
}
En una hoja de estilo condicional IE9:
.btn { filter: none; }
Siempre que la hoja de estilo IE9 esté referenciada en su cabeza después de la hoja de estilo principal, esto funcionará perfectamente.
La máscara div en IE9 es una buena idea. Estoy suministrando un código completo para ayudar a aclarar un poco. Si bien no estoy contento con envolver el botón en un DIV, creo que es más fácil de entender que incrustar una máscara PNG o pasar todo el esfuerzo usando SVG. Tal vez IE 10 lo soporte adecuadamente.
<!DOCTYPE html>
<html>
<head>
<title>Button Test</title>
<style>
.btn_mask { cursor:pointer;padding:5px 10px;border-radius:11px 11px 11px 11px;
background-color:transparent;-moz-border-radius:11px 11px 11px 11px;
-webkit-border-radius:11px 11px 11px 11px;overflow:hidden;padding:0px;
float:left; }
.btn { cursor:pointer;text-decoration:none;border:1px solid rgb(153,153,153);
padding:5px 10px;color:rgb(0,0,0);font-size:14px;font-family:arial,serif;
text-shadow:0px 0px 5px rgb(255,255,255);font-size:14px;
border-radius:11px 11px 11px 11px;-moz-border-radius:11px 11px 11px 11px;
-webkit-border-radius:11px 11px 11px 11px;box-shadow:0px 0px 0px rgb(0,0,0);
-moz-box-shadow:0px 0px 0px rgb(0,0,0);
-webkit-box-shadow:0px 0px 0px rgb(0,0,0);background-color:rgb(255,204,0);
background-image:linear-gradient(-90deg,rgb(255,255,153),rgb(255,204,0));
background-image:-webkit-gradient(linear,50% 0%,50% 100%,from(rgb(255,255,153)),to(rgb(255,204,0)));-ms-filter:"progid:DXImageTransform.Microsoft.gradient(startColorStr=''#ffffff'', EndColorStr=''#ffcc00)'')";background-image:-moz-linear-gradient(-90deg,rgb(255,255,153),rgb(255,204,0));
}
.btn:hover { cursor:pointer;text-decoration:none; border:1px solid rgb(153,153,153); padding:5px 10px 5px 10px; color:rgb(0,0,0); font-size:14px; font-family:arial,serif; text-shadow:0px 0px 5px rgb(255,255,255); font-size:14px; border-radius:11px 11px 11px 11px; -moz-border-radius:11px 11px 11px 11px; -webkit-border-radius:11px 11px 11px 11px; box-shadow:0px 0px 0px rgb(0,0,0); -moz-box-shadow:0px 0px 0px rgb(0,0,0); -webkit-box-shadow:0px 0px 0px rgb(0,0,0); background-color:rgb(255,255,0); background-image:linear-gradient(-90deg,rgb(255,255,0),rgb(255,255,153)); background-image:-webkit-gradient(linear,50% 0%,50% 100%,from(rgb(255,255,0)),to(rgb(255,255,153))); background-image:-moz-linear-gradient(-90deg,rgb(255,255,0),rgb(255,255,153)); }
</style>
</head>
<body>
<form name=''form1''>
<div class=''btn_mask''><input type=''button'' class=''btn'' value=''a button''></div>
<div class=''btn_mask''><input type=''button'' class=''btn'' value=''a button''></div>
<div class=''btn_mask''><input type=''button'' class=''btn'' value=''a button''></div>
<div class=''btn_mask''><input type=''button'' class=''btn'' value=''a button''></div>
</form>
</body>
</html>
Me encontré con este error también. Mi sugerencia sería utilizar una imagen de fondo repetida para el gradiente en ie9. IE9 coloca correctamente en mosaico la imagen detrás de los bordes redondeados (a partir de RC1).
No veo cómo escribir 100 líneas de código para reemplazar 1 línea de CSS es simple o elegante. SVG es genial y todo, pero ¿por qué pasar por todo eso cuando las soluciones más fáciles para fondos de gradiente han existido durante años?
No estoy seguro de si se trata de una solución única o válida, pero ...
Descubrí que si el radio del borde es mayor que el ancho del borde, no encontré el problema. Cuando eran iguales yo conseguía las esquinas cuadradas.
Podría usar la sombra para lograr un gradiente y va a trabajar en Internet Explorer 9 con border-radius
Algo como esto:
box-shadow: inset 0px 0px 26px 5px gainsboro;
Simplemente use un div envoltorio (redondeado y desbordado oculto) para recortar el radio para IE9. Sencillo, funciona cross-browser. SVG, JS, y comentarios condicionales son innecesarios.
<div class="ie9roundedgradient"><div class="roundedgradient">text or whatever</div></div>
.ie9roundedgradient {
display:inline-block; overflow:hidden; -webkit-border-radius: 8px; -moz-border-radius: 8px; border-radius: 8px;
}
.roundedgradient {
-webkit-border-radius: 8px; -moz-border-radius: 8px; border-radius: 8px;
/* use colorzilla to generate your cross-browser gradients */
}
También he estado trabajando con este problema. Otra "solución" es agregar un div alrededor del elemento que tiene el degradado y las esquinas redondeadas. Haga que div tengan los mismos valores de alto, ancho y esquina redondeada. Establecer el desbordamiento en oculto. Esto es básicamente una máscara, pero funciona para mí.
HTML:
<div class="mask roundedCorners">
<div class="roundedCorners gradient">
Content
</div>
</div>
CSS:
.mask
{
overflow: hidden;
}
.roundedCorners
{
border-radius: 5px;
-moz-border-radius: 5px;
-webkit-border-radius: 5px;
}
.gradient
{
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr=''#0065a4'', endColorstr=''#a0cf67'',GradientType=0 ); /* IE6-9 */
}
También me quedé atascado en el mismo problema n descubrí que IE no puede representar el radio del borde y el degradado a la vez, ambos conflictos, la única manera de resolver este dolor de cabeza es eliminar el filtro y usar el degradado mediante el código svg, solo para IE ..
puede obtener el código svg utilizando su código de color degradado, de Microsoft este sitio (especialmente diseñado para gradiente a svg):
http://ie.microsoft.com/testdrive/graphics/svggradientbackgroundmaker/default.html
disfrutar :)
También puede usar CSS3 PIE para resolver este problema:
Por supuesto, eso podría ser una exageración si solo depende de un solo elemento con esquinas redondeadas y un degradado de fondo, pero es una opción a considerar si está incorporando una serie de características comunes de CSS3 en sus páginas y desea un soporte fácil para IE6 +
Usando brújula y descaro, puedes lograr esto fácilmente así:
@import "compass";
#border-radius {
@include border-radius(''RADIUS''px); }
#gradiant{
$experimental-support-for-svg: true;
@include background-image(linear-gradient(''COLOR'') %,(''COLOR'') %,...; }
Compass generará una imagen SVG para ti.
al igual que:
#gradiant {
background-image: url('''');
background-size: 100%;
background-image: -webkit-gradient(linear, to bottom, to top, color-stop(0%, #082a2e), color-stop(35%, rgba(8, 42, 46, 0.76)), color-stop(43%, rgba(7, 43, 47, 0.71)), color-stop(58%, rgba(4, 44, 50, 0.58)), color-stop(100%, #042c32));
background-image: -webkit-linear-gradient(to bottom, #082a2e 0%, rgba(8, 42, 46, 0.76) 35%, rgba(7, 43, 47, 0.71) 43%, rgba(4, 44, 50, 0.58) 58%, #042c32 100%);
background-image: -moz-linear-gradient(to bottom, #082a2e 0%, rgba(8, 42, 46, 0.76) 35%, rgba(7, 43, 47, 0.71) 43%, rgba(4, 44, 50, 0.58) 58%, #042c32 100%);
background-image: -o-linear-gradient(to bottom, #082a2e 0%, rgba(8, 42, 46, 0.76) 35%, rgba(7, 43, 47, 0.71) 43%, rgba(4, 44, 50, 0.58) 58%, #042c32 100%);
background-image: linear-gradient(to bottom, #082a2e 0%, rgba(8, 42, 46, 0.76) 35%, rgba(7, 43, 47, 0.71) 43%, rgba(4, 44, 50, 0.58) 58%, #042c32 100%);
}
/* line 28, ../sass/boxshadow.scss */
#border-radius {
-moz-border-radius-topright: 8px;
-webkit-border-top-right-radius: 8px;
border-top-right-radius: 8px;
-moz-border-radius-bottomright: 8px;
-webkit-border-bottom-right-radius: 8px;
border-bottom-right-radius: 8px;
}
background: #4f81bd; /* Old browsers */
/* IE9 SVG, needs conditional override of ''filter'' to ''none'' */
background: url();
background: -moz-linear-gradient(left, #4f81bd 0%, #8abbd7 100%); /* FF3.6+ */
background: -webkit-gradient(linear, left top, right top, color-stop(0%,#4f81bd), color-stop(100%,#8abbd7)); /* Chrome,Safari4+ */
background: -webkit-linear-gradient(left, #4f81bd 0%,#8abbd7 100%); /* Chrome10+,Safari5.1+ */
background: -o-linear-gradient(left, #4f81bd 0%,#8abbd7 100%); /* Opera 11.10+ */
background: -ms-linear-gradient(left, #4f81bd 0%,#8abbd7 100%); /* IE10+ */
background: linear-gradient(left, #4f81bd 0%,#8abbd7 100%); /* W3C */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr=''#4f81bd'', endColorstr=''#8abbd7'',GradientType=1 ); /* IE6-8 */
Me estaba haciendo esto y una vez que quité la línea del "filtro", el sangrado desapareció. Además yo uso PIE.
Sangrado
background: #8abbd7; /* Old browsers */
/* IE9 SVG, needs conditional override of ''filter'' to ''none'' */
background: url();
background: -moz-linear-gradient(top, #8abbd7 0%, #4f81bd 100%); /* FF3.6+ */
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#8abbd7), color-stop(100%,#4f81bd)); /* Chrome,Safari4+ */
background: -webkit-linear-gradient(top, #8abbd7 0%,#4f81bd 100%); /* Chrome10+,Safari5.1+ */
background: -o-linear-gradient(top, #8abbd7 0%,#4f81bd 100%); /* Opera 11.10+ */
background: -ms-linear-gradient(top, #8abbd7 0%,#4f81bd 100%); /* IE10+ */
background: linear-gradient(top, #8abbd7 0%,#4f81bd 100%); /* W3C */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr=''#8abbd7'', endColorstr=''#4f81bd'',GradientType=0 ); /* IE6-8 */
-pie-background: linear-gradient(#8ABBD7, #4f81bd);
behavior: url(../PIE/PIE.htc);
No sangra:
background: #8abbd7; /* Old browsers */
/* IE9 SVG, needs conditional override of ''filter'' to ''none'' */
background: url();
background: -moz-linear-gradient(top, #8abbd7 0%, #4f81bd 100%); /* FF3.6+ */
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#8abbd7), color-stop(100%,#4f81bd)); /* Chrome,Safari4+ */
background: -webkit-linear-gradient(top, #8abbd7 0%,#4f81bd 100%); /* Chrome10+,Safari5.1+ */
background: -o-linear-gradient(top, #8abbd7 0%,#4f81bd 100%); /* Opera 11.10+ */
background: -ms-linear-gradient(top, #8abbd7 0%,#4f81bd 100%); /* IE10+ */
background: linear-gradient(top, #8abbd7 0%,#4f81bd 100%); /* W3C */
-pie-background: linear-gradient(#8ABBD7, #4f81bd);
behavior: url(../PIE/PIE.htc);
Quick IE Shadow Fix:
fixBoxShadowBlur($(''*''));
function fixBoxShadowBlur(jQueryObject){
if($.browser.msie && $.browser.version.substr(0, 1) == ''9''){
jQueryObject.each(function(){
boxShadow = $(this).css(''boxShadow'');
if(boxShadow != ''none''){
var bsArr = boxShadow.split('' '');
bsBlur = parseInt(bsArr[2]) || 0;
bsBlurMeasureType = bsArr[2].substr(("" + bsBlur).length);
bsArr[2] = (bsBlur * 2) + bsBlurMeasureType;
$(this).css(''boxShadow'', bsArr.join('' ''));
}
});
}
}