IE9边界半径和背景渐变出血


191

IE9显然可以通过使用CSS3标准定义来处理圆角border-radius

支持边界半径背景渐变怎么样?是的,IE9分别支持它们,但是如果将两者混合使用,则渐变会从圆角流出。

我还看到阴影在圆角框下面显示为实心黑线的奇怪现象。

这是IE9中显示的图像:

图像无出血,但角落清晰 图像有出血

我该如何解决此问题?


感谢@MikeP和@meanstreakuk的提示。我想我正在寻找的答案更多是根据IE何时真正支持渐变/舍入或如何使两者一起使用来实现。
SigmaBetaTooth

您可以从@meanstreak获得有关如何使2一起工作的答案。如果您想现实一点,SVG渐变作为背景图像的可能性要比css渐变(仍处于开发/讨论阶段)要早得多,所有浏览器都完全支持SVG渐变。
凯文·佩诺

29
令人难以置信的MS远远落后。现在是2011年,IE仍在处理此类问题。zzzzzzz。..在他们的网站上,他们说:“快速就是美丽”。当然是啦。看看上面发布的图片。什么是矩形美!
2011年

好吧,包含有圆角的东西中的Chrome元素中的SunnyRed,在拐角处流血。确实是2012年,浏览器仍在处理此类问题:-)
Joey

2
@SunnyRed现在是2013年,错误仍然存​​在:(
4

Answers:


49

这是添加背景渐变的一种解决方案,它使用数据URI创建覆盖任何背景颜色的半透明图像。我已验证它已正确裁剪到IE9中的边框半径。与基于SVG的提案相比,此方法较轻,但缺点是,与分辨率无关。另一个优点:与您当前的HTML / CSS一起使用,不需要使用其他元素进行包装。

我通过网络搜索抓取了一个随机的20x20渐变PNG,然后使用在线工具将其转换为数据URI。对于所有SVG混乱,所得到的数据URI比CSS代码小,而SVG本身就小得多!(您可以仅使用条件样式,特定于浏览器的CSS类等将此条件有条件地应用于IE9。)当然,生成PNG非常适合按钮大小的渐变,但不适用于页面大小的渐变!

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

1
而赢家是...我想我是否必须选一个。我希望看到有关IE何时真正支持它所说的支持的更多信息。至于背景图像解决方案,我倾向于不引入图像以使IE正常运行。感谢大家的有用建议。
SigmaBetaTooth 2011年

1
我发现设置background-size: 100% 103%; background-position:center;更好。两个值的100%都会在顶部和底部添加一些奇怪的边框。
Morten Christiansen

加上背景尺寸:100%103%;背景位置:中心;对我没有任何帮助
格雷戈里·博肯斯汀

2
不太确定为什么要使用数据uri而不仅仅是图像?我想图像会给ie9用户带来对服务器的额外调用,但是将所有这些额外的字符发送到非IE9浏览器似乎是浪费的。解决方案对我来说是一个形象,不胜感激。
诱饵

4
他的手动数据URI是一些CSS预处理器通常在部署期间执行的操作。从“但是那是什么丑陋的骇客”开始,这就是一个废话。SVG与其他任何图像一样,都是矢量。因此,将SVG称为hack,并提出PNG绝对是胡说八道。SVG为什么更好?分辨率独立性,与使用边框半径而不是栅格化图像背景的原因相同。
skrat 2012年

104

我也一直在研究这个问题。另一个“解决方案”是在具有渐变和圆角的项目周围添加一个div。使该div具有相同的高度,宽度和圆角值。将溢出设置为隐藏。这基本上只是一个面具,但对我有用。

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

3
这对我来说非常有效,并且比其他建议的解决方案简单得多。
西蒙·史蒂文斯

比目前接受的答案容易得多。这对我来说在IE9中有效。
Andy McCluggage 2012年

这行得通...太可悲和可悲了。这是“ HTML5”浏览器!为什么我对IE10感到不满意。
托德·万斯

@toddv别担心。一切都快结束了。还不够,但是很快。请参阅daringfireball.net/linked/2012/07/04/windows-hegemony 运气不错,没有人会担心支持IE12 ...也许是IE14-它变得模糊。
jinglesthula 2012年

2
只是一点点注意,但您的边框半径声明应颠倒以增强向前兼容性。我进行了编辑。
帕里斯(Parris)2012年

44

我认为值得一提的是,在许多情况下,您可以使用插入框阴影来“伪造”渐变效果并避免IE9中的难看边缘。这对于按钮尤其有效。

参见以下示例:http : //jsfiddle.net/jancbeck/CJPPW/31/

具有线性渐变或矩形阴影的按钮样式的比较


2
就我而言,这是出色的解决方案,因为我只在按钮上使用了它,就像您绘制时一样需要渐变。我box-shadow: inset 0 -8px 10px rgba(0,0,0,0.15), 0 1px 0 rgba(255,255,255, 0.3), inset 0 1px 0 rgba(255,255,255, 0.3);
暂时

优雅而简单。我++。
伊莱兰·马尔卡

1
+1跳出框框思考。对于标签和按钮都非常有效。使用插图可将渐变保留在元素内部。
GlennG

这是我见过的最好的解决方案。纯CSS,不需要额外的元素或图像。
Zaqx

1
不错的技巧,但我在整个网站上都有渐变。我不能改变他们所有的愚蠢,即。
Mehmet FatihYıldız2013年

8

您还可以使用CSS3 PIE解决此问题:

http://css3pie.com/

当然,如果仅依赖于带有圆角和背景渐变的单个元素,那可能会过大。但是,如果您要在页面上合并许多通用的CSS3功能并希望获得轻松支持,则可以考虑采用这种方法对于IE6 +


1
即使使用css3pie和ie9,我也看不到渐变。我看到圆角和阴影,但没有渐变。
凯文

7

我也遇到了这个错误。我的建议是对ie9中的渐变使用重复的背景图像。IE9正确将图像平铺在圆角边框的后面(从RC1开始)。

我看不到编写100行代码来替换1行CSS是多么简单或优雅。SVG非常酷,但是,当渐变背景更简单的解决方案已经存在多年时,为什么还要经历所有这些。



5

只需使用包装div(隐藏并四舍五入)就可以裁剪IE9的半径。简单,可以跨浏览器使用。不需要SVG,JS和条件注释。

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

4

这篇博文对我有帮助:http : //abouthalf.com/2010/10/25/internet-explorer-9-gradients-with-rounded-corners/

基本上,您可以使用条件注释来删除过滤器,然后创建可以用作背景图像的SVG渐变“精灵”。

简洁大方!


我住这个。最终帮助我结束关于如何使用SVG创建子画面的搜索时尤其如此。由于SVG是可缩放的,并且sprite是可能的,因此我发现SVG sprite包比CSS渐变具有更多的用途,并且正如我上面所说,在CSS渐变之前,浏览器可能会获得100%的支持。
凯文·佩诺

哦,我要补充的是当前的webkit,而且我相信Opera也支持CSS图像url()调用中的SVG 。仅剩一个保留,因此,丢弃了1000个条件,并在所有支持它的bg上提供了SVG。对于其他所有人,请提供光栅图像。然后,这种黑客变得可管理。
凯文·佩诺

4

IE9可以正确处理边界半径和渐变。问题是,IE9正确呈现过滤器除了梯度。正确解决此问题的方法是在使用filter属性的样式声明中禁用过滤器。

作为如何最好地解决此问题的示例:

您的主样式表中有一个按钮类。

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

在条件IE9样式表中:

.btn { filter: none; }

只要您的主要样式表之后在您的脑海中引用了IE9样式表,它就可以完美地工作。


2
ie9不会渲染线性渐变
James Westgate

3

有一种简单的方法可以使它在IE9下仅需一个元素即可工作。

看看这个小提琴:http : //jsfiddle.net/bhaBJ/6/

第一个元素设置边界半径。第二个伪元素设置背景渐变。

几个主要说明:

  • 父母必须有亲戚或绝对位置
  • 父母必须有溢出:隐藏;(以使边界半径效果可见)
  • :: before(或:: after)伪元素必须具有z-index:-1(替代方法)

基本元素声明类似于:

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

伪元素声明:

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

}

刚刚好!谢谢!:)
majimekun 2014年

我在您的示例中将border-radius设置为20,并且IE9中的边界没有被剪裁–于2015
暗恋

尝试在标题中设置以下内容:<meta http-equiv =“ X-UA-Compatible” content =“ IE = 9” />
Marakoss 2015年

2

我决定禁用IE9,以解决此错误。它是干净,容易且通用的。

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

1

IE9中的mask div是个好主意。我正在提供一些完整的代码来帮助您进行澄清。尽管我不满意将按钮包装在DIV中,但我认为它比嵌入PNG蒙版或使用SVG进行所有工作更容易理解。也许IE 10会正确支持它。

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

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

对我这样做时,一旦我删除了“ filter:”行,出血就消失了。另外,我使用PIE。

出血:

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

不流血:

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

快速IE阴影修复:

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

}


1

您可以使用阴影来实现渐变,并且可以在Internet Explorer 9上使用border-radius

像这样:

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

0

不知道这是一次还是有效的解决方法,但是...

我发现只要边界半径大于边界宽度,就不会遇到问题。当它们相同的时候,我正处于四角。


0

使用指南针和无礼的话,您可以轻松实现以下目标:

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

指南针将为您生成SVG图像。

像这样:

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

}


0

为我工作...

<!--[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%);
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.