我对ie8和9浏览器的梯度mixin有一个问题,因为渐变mixin似乎有一点bug,因为gradien的hexa代码有很多字符来自bootstrap mixin。如果有人重写了这个问题并解决了请分享。 这不是来自bootstrap的混合:
.vertical(@start-color: #555; @end-color: #333; @start-percent: 0%; @end-percent: 100%) {
background-image: -webkit-linear-gradient(top, @start-color @start-percent, @end-color @end-percent); // Safari 5.1-6, Chrome 10+
background-image: linear-gradient(to bottom, @start-color @start-percent, @end-color @end-percent); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+
background-repeat: repeat-x;
filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=0)",argb(@start-color),argb(@end-color))); // IE9 and down
}
变量:
@table-header1: rgba(155,214,45,0.65);
@table-header2: rgba(123,192,67,0.99);
less:
.table {
thead tr {
font-weight:normal;
#gradient > .vertical(@table-header1 , @table-header2);
th {
text-shadow: 0 1px 0 rgba(255, 255, 255, 0.9);
color: @asf-table-th-color;
border-color:#428BCA;
border-width: 1px;
font-weight:bold;
}
}
}
这是mixin的结果:
.table thead tr {
font-weight: normal;
background-image: -webkit-linear-gradient(top, rgba(155, 214, 45, 0.65) 0%, rgba(123, 192, 67, 0.99) 100%);
background-image: linear-gradient(to bottom, rgba(155, 214, 45, 0.65) 0%, rgba(123, 192, 67, 0.99) 100%);
background-repeat: repeat-x;
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#a69bd62d', endColorstr='#fc7bc043', GradientType=0);
}
现在,如果仔细查看十六进制代码,即滤镜渐变有多个字符。
这是具有正确十六进制代码的ie8渐变的示例:
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#1e5799', endColorstr='#7db9e8',GradientType=0 );
答案 0 :(得分:1)
您正确的十六进制值的示例是错误的,您可以在http://msdn.microsoft.com/en-us/library/ms532930(v=vs.85).aspx看到StartColorStr应该设置为:
颜色以#AARRGGBB格式表示,其中AA是alpha 十六进制值,RR是红色十六进制值,GG是绿色 十六进制值,BB是蓝色十六进制值。阿尔法 value控制对象的不透明度。 alpha值为00 透明,而FF的值是不透明的。字符串输入是 在十六进制范围之外将恢复为默认值(#FF0000FF)。