如何为 IE8 应用线性渐变
Posted
技术标签:
【中文标题】如何为 IE8 应用线性渐变【英文标题】:How to apply linear gradient for IE8 【发布时间】:2013-06-10 13:57:03 【问题描述】:线性渐变适用于除 IE8 以外的所有浏览器。
我添加了progid:DXImageTransform.Microsoft.gradient
...这确实给了它一些渐变,但是预期的结果是不同的。
代码:-
div
height:500px;width:500px;
background-size: 50px 50px;
background-color: #DDEEEE;
background-image: -webkit-linear-gradient(rgba(255, 255, 255, .2) 50%, transparent 50%, transparent);
background-image: -moz-linear-gradient(rgba(255, 255, 255, .2) 50%, transparent 50%, transparent);
background-image: -ms-linear-gradient(rgba(255, 255, 255, .2) 50%, transparent 50%, transparent);
background-image: -o-linear-gradient(rgba(255, 255, 255, .2) 50%, transparent 50%, transparent);
background-image: linear-gradient(rgba(255, 255, 255, .2) 50%, transparent 50%, transparent);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#DDEEEE',GradientType=0 );
如何使这个渐变线性化?
【问题讨论】:
【参考方案1】:我用来创建线性渐变的css如下。在 IE8 中也可以正常工作。似乎与您的唯一区别是我将 gradientType 设置为 1(水平),而不是 0(垂直),并且我使用不同的颜色。
<div></div>
css
divwidth:400px;height:200px;
/*gradient background color */
background: #0071a0; /* Old browsers */
background: -moz-linear-gradient(left, #0071a0 1%, #ff0000 100%); /* FF3.6+ */
background: -webkit-gradient(linear, left top, right top, color-stop(1%,#0071a0), color-stop(100%,#ff0000)); /* Chrome,Safari4+ */
background: -webkit-linear-gradient(left, #0071a0 1%,#00a3ca 100%); /* Chrome10+,Safari5.1+ */
background: -o-linear-gradient(left, #0071a0 1%,#ff0000 100%); /* Opera 11.10+ */
background: -ms-linear-gradient(left, #0071a0 1%,#ff0000 100%); /* IE10+ */
background: linear-gradient(to right, #0071a0 1%,#ff0000 100%); /* W3C */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0071a0', endColorstr='#ff0000',GradientType=1 ); /* IE6-9 */
http://jsfiddle.net/yAxbJ/
另一个问题是您使用接近白色的颜色,因此渐变效果不那么明显。尝试更改为更明显的起始颜色,例如 #ff000 以查看渐变是否真正起作用。你还有一个重复的背景颜色值。
【讨论】:
感谢 Luke 指出我多余的 background-color 值,它现在已被编辑,但是我无法在您的小提琴中将 gradientType 设置为 1。此外,我使用的是背景图像而不是背景。还有什么我可以尝试的吗? gradientType 只是改变 IE 中的渐变方向 - jsfiddle.net/yAxbJ/1 - background 是所有背景属性的简写。 background-image 应该专门用于图像,即 background-image:url('image.jpg');看这里 - ***.com/questions/10205464/… 我对尝试什么没有任何进一步的建议。我之前提供的代码应该可以在 IE8 中为您工作...filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0071a0', endColorstr='#ff0000',GradientType=1 ); /* IE6-9 */
是一个真正的宝石。以上是关于如何为 IE8 应用线性渐变的主要内容,如果未能解决你的问题,请参考以下文章
如何在 Flutter for android 中创建这种线性渐变不透明度效果?