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

IE9显然能够通过使用 CSS3的 border-radius标准定义来处理圆角。

如何支持边界半径 还有背景梯度?是的,IE9是分别支持两者,但是如果你混合了两者,渐变就会从圆角流出。

我还看到奇怪的阴影显示为一个圆角框下的一个坚实的黑线。

下面是 IE9中显示的图片:

image with no bleed, but sharp cornersimage with bleed

我怎样才能解决这个问题?

77298 次浏览

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

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

简洁而优雅!

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

我看不出编写100行代码来代替1行 CSS 是简单还是优雅的。SVG 确实很酷,但是为什么要经历这些呢? 因为渐变背景的简单解决方案已经出现了很多年了。

你也可以使用 CSS3 PIE 来解决这个问题:

Http://css3pie.com/

当然,如果你只是依赖于一个圆角和背景渐变的单个元素,这可能有点夸张,但是如果你想在你的页面上加入一些 CSS3的常见功能,并且想要对 IE6 + 的简单支持,这是一个可以考虑的选项

这里有一个添加背景渐变的解决方案,使用数据 URI 创建覆盖任何背景颜色的半透明图像。我已经确认它被正确地剪切到 IE9的边界半径。这比基于 SVG 的提议更轻量级,但是作为一个缺点,它与分辨率无关。另一个优点是: 可以使用当前的 HTML/CSS,不需要使用其他元素进行包装。

我抓取了一个随机的20x20梯度 PNG 通过网络搜索,并转换成一个数据 URI 使用在线工具。由此产生的数据 URI 比所有 SVG 混乱的 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;
}

我也一直在解决这个问题。另一个“解决方案”是在有渐变和圆角的条目周围添加一个 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 */
}

IE9中的掩码 div 是个好主意。我提供了一些完整的代码,以帮助澄清一点。虽然我不喜欢将按钮包装在 DIV 中,但我认为这比嵌入 PNG 掩码或使用 SVG 完成所有工作更容易理解。也许 IE10会正确地支持它。

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

我决定在圆角处禁用 IE9来解决这个 bug。 它是干净的,容易和通用的可用。

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

我这样做,一旦我删除“过滤器:”线,出血消失。 而且我用馅饼。

出血:

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

}

我认为值得一提的是,在很多情况下,你可以使用插入框阴影来“伪造”渐变效果,避免 IE9中的丑陋边缘。这对按钮特别有效。

看这个例子: http://jsfiddle.net/jancbeck/CJPPW/31/

Comparison of a button style with either linear gradient or box-shadow

不确定这是一次性的还是有效的解决方案,但是..。

我发现,如果边界半径大于边界宽度,我就不会遇到这个问题。当他们是相同的,我得到了方角。

你可以使用 影子来实现渐变,然后用 border-radius来处理 Internet Explorer 9

就像这样:

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

使用指南针和顶嘴,你可以很容易地做到这一点,就像这样:

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

Compass 将为您生成一个 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;

}

IE9正确地处理边界半径和渐变。问题是 IE9将滤波器本身 除了呈现为渐变。正确解决这个问题的方法是在使用过滤器属性的样式声明上禁用过滤器。

作为如何最好地解决这个问题的一个例子:

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

.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样式表在你的头部 之后中被引用,你的主样式表就会完美地工作。

我也遇到了同样的问题 n 发现 IE 不能同时渲染边界半径和渐变,它们都是冲突的,解决这个问题的唯一方法就是删除过滤器,通过 svg 代码使用渐变,只是为了 IE。.

你可以通过使用他们的渐变颜色代码来获得 svg 代码,来自 Microsoft 这个站点(专门为渐变到 svg 而设计) :

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

享受:)

只需使用一个包装 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 */
}

对我有用。

<!--[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%);

有一个简单的方法可以让它在 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 );


}