栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Html/CSS > CSS教程

CSS3实现原型进度条效果

CSS教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

CSS3实现原型进度条效果

今天早上在群里看到有同学问如何用 CSS3 实现以下效果?

一开始我觉得 CSS3 搞不出来这种效果的吧,主要是白色透明那个地方,后来灵机一动想到了渐变至透明色(不考虑兼容性的情况)应该是可以做出来的。如果你对 CSS3 比较熟悉的话,那么你应该对渐变效果 linear-gradient 也不陌生,不了解的同学可以去查阅文档。

首先我们对这个结构进行一下拆分,看下图所示:

有的同学一看到这张图就已经知道该怎么做了,对,就是用 border-radius + 遮罩。先用 border-radius 做一个圆出来,再加上线性渐变色,中间部分用伪类也做一个圆,定位过去盖上,于是就有了外面的空心圆,即下图所示:

代码如下:

.box1 {
  width: 100px;
  height: 100px;
  position: relative;
  border-radius: 50%;
  background-image: linear-gradient(
    60deg,
    #f79533,
    #f37055,
    #ef4e7b,
    #a166ab,
    #5073b8,
    #1098ad,
    #07b39b,
    #6fba82);
  background-image: linear-gradient(
    60deg,
    #f79533,
    #f37055,
    #ef4e7b,
    #a166ab,
    #5073b8,
    #1098ad,
    #07b39b,
    #6fba82);
}
.box1:after {
  width: 90px;
  height: 90px;
  position: absolute;
  top: 5px;
  left: 5px;
  background-color: #fff;
  content: ' ';
  border-radius: 50%;
}
.box1:before {
  width: 50px;
  height: 50px;
  position: absolute;
  top: 50px;
  left: 50px;
  content: ' ';
  background-image: -webkit-linear-gradient(right top, white 60%, transparent);
  background-image:linear-gradient(right top, white 60%, transparent);
}

接下来就是最重要的一步了,用线性渐变画出遮罩层,直接上代码吧:

.box1:before {
  width: 50px;
  height: 50px;
  position: absolute;
  top: 50px;
  left: 50px;
  content: ' ';
  background-image: -webkit-linear-gradient(right top, white 60%, transparent);
  background-image:linear-gradient(right top, white 60%, transparent);
}

这样一来我们就实现了上面的效果,完整代码如下:




  
  document
  
    .box1 {
      width: 100px;
      height: 100px;
      position: relative;
      border-radius: 50%;
      background-image: linear-gradient(
 60deg,
 #f79533,
 #f37055,
 #ef4e7b,
 #a166ab,
 #5073b8,
 #1098ad,
 #07b39b,
 #6fba82);
      background-image: linear-gradient(
 60deg,
 #f79533,
 #f37055,
 #ef4e7b,
 #a166ab,
 #5073b8,
 #1098ad,
 #07b39b,
 #6fba82);
    }
    .box1:after {
      width: 90px;
      height: 90px;
      position: absolute;
      top: 5px;
      left: 5px;
      background-color: #fff;
      content: ' ';
      border-radius: 50%;
    }
    .box1:before {
      width: 50px;
      height: 50px;
      position: absolute;
      top: 50px;
      left: 50px;
      content: ' ';
      background-image: -webkit-linear-gradient(right top, white 60%, transparent);
      background-image:linear-gradient(right top, white 60%, transparent);
    }
  


  
  

最终效果图:

原文地址:点我

转载请注明:文章转载自 www.mshxw.com
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号