Domanda

IE9 è apparentemente in grado di gestire gli angoli arrotondati utilizzando la definizione standard CSS3 di border-radius.

Che dire di supporto per il raggio di frontiera e sfondo sfumato? Sì IE9 è quello di sostenerli sia separatamente, ma se si mescolano i due il gradiente sanguina la coda arrotondata.

Sono anche vedendo stranezza con le ombre che mostrano come una linea nera continua sotto una scatola con gli angoli arrotondati.

Ecco le immagini mostrate in IE9:

immagine senza sanguinare, ma spigoli vivi immagine con spurgo

Come posso risolvere questo problema?

È stato utile?

Soluzione

Ecco un soluzione che aggiunge una sfumatura di sfondo, utilizzando un URI di dati per creare un'immagine semi-trasparente che si sovrappone qualsiasi colore di sfondo. Ho verificato che è ritagliato correttamente al raggio confine in IE9. Questo è il peso più leggero di proposte SVG-based, ma come un aspetto negativo, non è indipendente dalla risoluzione. Un altro vantaggio:. Funziona con il vostro attuale HTML / CSS e non richiede che sposta con elementi aggiuntivi

Ho afferrato un casuale PNG 20x20 gradiente tramite una ricerca sul web, e lo trasformò in un data URI utilizzando uno strumento online. I dati risultanti URI è più piccolo del codice CSS per tutto ciò che SVG casino, tanto meno lo SVG in sé! (Si potrebbe applicare questo condizionatamente al IE9 solo con stili condizionali, le classi CSS specifiche per il browser, ecc) Naturalmente, generando un PNG funziona alla grande per le sfumature dei pulsanti di dimensioni, ma non di pagina di dimensioni gradienti!

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

Altri suggerimenti

Inoltre ho lavorato con questo problema. Un'altra "soluzione" è quella di aggiungere un div intorno l'elemento che ha il gradiente e angoli arrotondati. Fare che div la stessa altezza, la larghezza e valori angolari arrotondati. Impostare l'overflow di nascosto. Questo è fondamentalmente solo una maschera, ma funziona per me.

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 */
}

Credo che sia la pena ricordare che in molti casi è possibile utilizzare un inserto box-shadow a "falso" l'effetto gradiente ed evitare i bordi brutte in IE9. Questo funziona bene soprattutto con bottoni.

Vedere questo esempio: http://jsfiddle.net/jancbeck/CJPPW/31/

Confronto di uno stile pulsante o con pendenza lineare o box-shadow

È inoltre possibile utilizzare CSS3 PIE per risolvere questo problema:

http://css3pie.com/

Naturalmente, che potrebbe essere eccessivo se si sta solo in funzione di un singolo elemento con angoli arrotondati e uno sfondo sfumato, ma è un'opzione da considerare se si sta incorporando un certo numero di CSS3 comuni caratteristiche sulle tue pagine e vogliono facile il supporto per IE6 +

mi sono imbattuto in questo errore anche. Il mio suggerimento sarebbe quello di utilizzare un'immagine di sfondo ripetuta per il gradiente in IE9. IE9 piastrelle correttamente l'immagine dietro i bordi arrotondati (come di RC1).

Non riesco a vedere come scrivere 100 righe di codice per sostituire 1 linea di CSS è semplice o elegante. SVG è fresco e tutto, ma perché passare attraverso tutto ciò che quando le soluzioni più semplici per gli sfondi sfumati sono stati in giro per anni.

Ho anche rimasto bloccato nello stesso problema n scoperto che IE non può rendere il raggio di confine e di pendenza sia a tempo, entrambi i conflitti, l'unico modo per risolvere questo mal di testa è quello di rimuovere il filtro e utilizzare il gradiente via codice SVG, solo per IE ..

è possibile ottenere il codice SVG usando il loro codice sfumatura di colore, da Microsoft questo sito (appositamente realizzati per gradiente di SVG):

http://ie.microsoft.com/testdrive/graphics/svggradientbackgroundmaker/default.html

godere:)

Basta usare un div involucro (overflow arrotondata e nascosto) per agganciare il raggio per IE9. Semplice, funziona cross-browser. SVG, JS, e condizionali commenti sono inutili.

<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 */ 
}

Questo post di blog mi ha aiutato: http : //abouthalf.com/2010/10/25/internet-explorer-9-gradients-with-rounded-corners/

In sostanza, si usa un commento condizionale per rimuovere il filtro e quindi creare 'sprite' SVG di gradienti che si può usare come immagini di sfondo.

Semplice ed elegante!

IE9 gestisce border-radius e gradienti insieme correttamente. Il problema è che IE9 rende il filtro corretto in aggiunta a il gradiente. Il modo per risolvere correttamente questo è quello di disattivare i filtri sulle dichiarazioni di stile che utilizzano la proprietà del filtro.

Per fare un esempio sul modo migliore di risolvere questo:

Si dispone di un pulsante di classe nel foglio di stile principale.

.btn {
    background: linear-gradient(to bottom,  #1e5799 0%,#7db9e8 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#1e5799', endColorstr='#7db9e8',GradientType=0 );
}

In un foglio di stile condizionale IE9:

.btn { filter: none; }

Fino a quando il foglio di stile IE9 fa riferimento nella vostra testa dopo foglio di stile questo formato funzionerà perfettamente.

C'è un modo semplice per farlo funzionare sotto IE9 con un solo elemento.

Date un'occhiata a questo violino: http://jsfiddle.net/bhaBJ/6/

Primo elemento imposta il border-radius. In secondo luogo pseudo-elemento imposta il gradiente di sfondo.

istruzioni fondamentali Poche:

  • genitore deve avere relativa o posizione assoluta
  • genitore deve avere overflow: hidden ; (Per effetto border-radius sia visibile)
  • :: prima (o dopo ::) pseudo-elemento deve avere z-index: -1 (soluzione di tipo)

Base dichiarazione elemento più o meno così:

.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*/
}

dichiarazione di pseudo-elemento:

.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 );

}

Ho deciso di disabilitare IE9 da arrotondare gli angoli per risolvere questo bug. E 'pulito, semplice e generica utilizzabile.

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

Il div maschera in IE9 è una buona idea. Sto alimentano alcune codice completo per contribuire a chiarire un po '. Mentre io non sono felice con avvolgendo il pulsante in un DIV, penso che sia più facile da capire di incorporare una maschera PNG o passare attraverso tutto lo sforzo con SVG. Forse IE 10 sosterrà in modo corretto.

<!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>
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 */

stava facendo questo a me e una volta ho rimosso il "filtro" linea l'emorragia è andato via. Inoltre io uso PIE.

Senza margini:

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

Non sanguinare:

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

Breve IE Ombra 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(' '));
        }
    });
}

}

Si potrebbe usare ombra per ottenere gradiente, e sta andando a lavorare su Internet Explorer 9 con border-radius

Qualcosa di simile a questo:

box-shadow: inset 0px 0px 26px 5px gainsboro;

Non so se questo era uno sconto o di una soluzione valida ma ...

ho scoperto che a condizione che il border-radius è maggiore della larghezza del bordo, non ho incontrato il problema. Quando furono lo stesso mi è stato sempre gli angoli quadrati.

Utilizzo della bussola e sass si può facilmente raggiungere questo obiettivo in questo modo:

@import "compass";
#border-radius {
@include border-radius('RADIUS'px); }
#gradiant{
$experimental-support-for-svg: true;
@include background-image(linear-gradient('COLOR') %,('COLOR') %,...; }

Compass genera un'immagine SVG per voi.

in questo modo:

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

}

funziona per me ...

<!--[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%);
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top