IE9 显然能够通过使用 CSS3 标准定义来处理圆角border-radius
。
对边框半径和背景渐变的支持怎么样?是的,IE9 是分别支持它们的,但是如果将两者混合,渐变会从圆角溢出。
我也看到了奇怪的阴影,在圆角的盒子下显示为一条实心黑线。
以下是 IE9 中显示的图像:
我该如何解决这个问题?
IE9 显然能够通过使用 CSS3 标准定义来处理圆角border-radius
。
对边框半径和背景渐变的支持怎么样?是的,IE9 是分别支持它们的,但是如果将两者混合,渐变会从圆角溢出。
我也看到了奇怪的阴影,在圆角的盒子下显示为一条实心黑线。
以下是 IE9 中显示的图像:
我该如何解决这个问题?
我也一直在解决这个问题。另一个“解决方案”是在具有渐变和圆角的项目周围添加一个 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 */
}
这是一种添加背景渐变的解决方案,使用数据 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;
}
我认为值得一提的是,在许多情况下,您可以使用插入框阴影来“伪造”渐变效果并避免 IE9 中的丑陋边缘。这对按钮特别有效。
见这个例子:http: //jsfiddle.net/jancbeck/CJPPW/31/
您还可以使用 CSS3 PIE 来解决此问题:
当然,如果您仅依赖于具有圆角和背景渐变的单个元素,这可能是矫枉过正,但如果您在页面上合并了许多常见的 CSS3 功能并希望获得简单的支持,这是一个考虑的选项适用于 IE6+
我也遇到了这个错误。我的建议是在 ie9 中为渐变使用重复的背景图像。IE9 正确地将图像平铺在圆形边框后面(从 RC1 开始)。
我看不出写 100 行代码来替换 1 行 CSS 是多么简单或优雅。SVG 很酷,但是当更简单的渐变背景解决方案已经存在多年时,为什么还要经历这一切。
我也遇到了同样的问题 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 */
}
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 样式表,这将完美地工作。
这篇博文帮助了我:http ://abouthalf.com/2010/10/25/internet-explorer-9-gradients-with-rounded-corners/
基本上,您使用条件注释来删除过滤器,然后创建可用作背景图像的渐变 SVG“精灵”。
简单优雅!
有一种简单的方法可以让它在 IE9 下工作,只需要一个元素。
看看这个小提琴:http: //jsfiddle.net/bhaBJ/6/
第一个元素设置边界半径。第二个伪元素设置背景渐变。
几个关键指令:
基本元素声明类似于:
.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 );
}
我决定从圆角禁用 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);
}
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 */
对我这样做,一旦我删除了“过滤器:”线,出血就消失了。另外,我使用 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(' '));
}
});
}
}
您可以使用阴影来实现渐变,并且将在 Internet Explorer 9 上使用border-radius
像这样的东西:
box-shadow: inset 0px 0px 26px 5px gainsboro;
IE9 中的掩码 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>
使用 compass 和 sass,您可以轻松地实现这一点,如下所示:
@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;
}
为我工作...
<!--[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%);
不确定这是一次性的还是有效的解决方法,但是...
我发现如果边框半径大于边框宽度,我没有遇到问题。当它们相同时,我得到了方角。