带有border-radius和背景渐变的HTML进度条

时间:2012-07-03 13:18:26

标签: html css css3 linear-gradients

我需要像这样制作一个进度条:

http://kashqool.com/files/progress-bar.png

它必须适用于(IE6 +,Chrome 3 +,Firefox 5 +,Opera 9+)。所以对于IE中的border-radius,我添加了ie-css3.htc但问题 - 在IE中,当我添加border-radius和带线性渐变的背景时,不会显示bordoer radius。 - 当DIV宽度为43%时,黑方可能不会显示。什么时候会100%显示出来。就像图片一样。

这是代码:

<!DOCTYPE HTML>
<html>

<head><title>Level 1</title>

<style type="text/css">

html,

body{
margin:0;
paddding:0; 

}

h3{
padding:0;
`margin`:0;
}

.progress_bar1{
behavior:url(ie-css3.htc);
background-color:white;
position:relative;
width:700px;
height:30px;
border:1px solid black; 
border-radius:8px;
-moz-border-radius: 8px;
-webkit-border-radius: 8px;
float:left;
padding:4px;

}

.first_bar{
behavior:url(ie-css3.htc);
background-color:white;
width:100%;
height:28px;
float:left; 
z-index:1;f

}

.div_100{
background-color:red;
width:100%;
filter: progid:DXImageTransform.Microsoft.gradient(gradientType=1, startColorstr=#FF8A2BE2, endColorstr=#FF000000);
background-image: -webkit-gradient(
    linear,
    left top, right top,
    from(blueviolet),
    to(black)
);
background-image: -webkit-linear-gradient(
    left,
    blueviolet,
    black
);
background-image: -moz-linear-gradient(
    left,
    blueviolet,
    black
);
background-image: -o-linear-gradient(
    left,
    blueviolet,
    black
);
background-image: linear-gradient(
    left,
    blueviolet,
    black
);

border-radius:8px;
-moz-border-radius: 8px;
-webkit-border-radius: 8px;
height:28px;
float:left;     
}

</style>

</head>

<body>
<h3> Level 1 </h3>
<div class="progress_bar1">
    <div class="first_bar">     
        <div class="div_100"></div>     
    </div>
</div>

</body>

</html>

2 个答案:

答案 0 :(得分:2)

我只是在这里猜测,但我认为结合背景渐变圆角黑客可能会导致一些奇怪的行为。

我只是简单地省略了IE6-8的圆角。它被称为'渐进增强'。更好的浏览器可以获得更好对于IE6-8,进度条仍然“有效”,它们只有方角而不是圆角。对象的重点 - 正在进行的进度 - 仍然适用于用户。您的用户不会从IE6转到Chrome并比较进度条。放手吧。

请参阅:http://dowebsitesneedtolookexactlythesameineverybrowser.com/

答案 1 :(得分:0)

Internet Explorer 6已经很老了,不支持css3。

  • 使用CSS3Pie作为ajm建议(我很惊讶,即使有效),
  • 使用javascript,
  • 使用圆形图像角落,
  • 或者只是接受它太旧了,用户应该更新他们的浏览器。