import React, { useState, useEffect } from "react"
import { css } from "emotion"

//num是从父级传来的百分比数值

export default function({ num }) {
let rightTrnas = css`
      transform: rotate(0deg);
`
let leftTrnas = css`
     transform: rotate(${0}deg);
 `
if (num <= 180) {
    rightTrnas = css`
       transform: rotate(${(Math.round(num * 100) / 100) * 3.6}deg);
    `
} else {
     rightTrnas = css`
        transform: rotate(180deg);
     `
     leftTrnas = css`
       transform: rotate(${(Math.round(num * 100) / 100) * 3.6 - 180}deg);
`
}
return (
        <div className={circleCss}>
               <div className="circle">
                     <div className="pie_left">
                          <div className={`left ${leftTrnas}`}></div>
                    </div>
                    <div className="pie_right">
                          <div className={`right ${rightTrnas}`}></div>
                    </div>
                   <div className="mask">
                            <span>{Math.round(num * 100) / 100}</span>%
                    </div>
              </div>
         </div>
     )
}
const circleCss = css`
         display: flex;
         justify-content: center;
         align-items: center;
         & .circle {
            width: 50px;
            height: 50px;
            position: relative;
            border-radius: 50%;
            background: #e9e9e9;
         }
       & .pie_left,
       & .pie_right {
           width: 50px;
           height: 50px;
           position: absolute;
           top: 0;
           left: 0;
        }
       & .left,
       & .right {
            width: 50px;
            height: 50px;
            background: #ff721c;
            border-radius: 50%;
            position: absolute;
            top: 0;
            left: 0;
          }
      & .pie_right,
      & .right {
          clip: rect(0, auto, auto, 25px);
       }
      & .pie_left,
      & .left { 
           clip: rect(0, 25px, auto, 0);
      }
      & .mask {
            width: 44px;
            height: 44px;
            border-radius: 50%;
            left: 3px;
            top: 3px;
            background: #fff;
            position: absolute;
            text-align: center;
            line-height: 44px;
            font-size: 12px;
            color: #ff721c;
       }
  `
如果要修改圆环的大小修改宽高和left ,right中的 clip: rect的值即可

react 实现圆环进度条的更多相关文章

  1. Vue/React圆环进度条

    数据展示,一直是各行各业乐此不疲的需求,具体到前端开发行业,则是各种各种图表数据展示,各种表格数据展示,烦不胜烦(繁不胜繁)! 前几天刚做了折线图.柱状图.饼状图之类的图表数据展示效果,今天又碰到了类 ...

  2. 两种CSS3圆环进度条详解

    晚上睡觉之前,我抽了1个多小时,研究了一下圆环进度条,结合从网上查阅的资料,我终于掌握了两种圆环的生成方法. 这次的效果就是单纯的CSS3效果,也没有写具体的JS,等以后有时间在好好整理一下吧~. 第 ...

  3. canvas绘制百分比圆环进度条

    开发项目,PM会跟踪项目进度:完成某个事情,也可以设置一个完成的进度. 这里用canvas绘制一个简单百分比圆环进度条. 看下效果: 1. 动画方式   2. 静默方式   // 贴上代码,仅供参考 ...

  4. svg实现圆环进度条

    开源实现:https://github.com/lugolabs/circles 自行实现:圆环与svg画布间剩的空间太多. <!DOCTYPE html> <html> &l ...

  5. css3 制作圆环进度条

    引子 移动端做一个 loadiing 加载的图标,跟以往沿用的都不太一样,是一个圆环进度条,圆环进度条也就罢了,还得能用百分比控制. CSS3 实现圆环 demo 刚开始写这个圆环的时候是参照帖子上给 ...

  6. CSS3实现圆环进度条

    摘要:圆环进度条被应用于各个场景,比如我们可以用来表示加载进度等.通常我们可以用 css3 的动画去实现. 详解 css3 实现圆环进度条 简单的画一个圆环,我们都知道如何使用 css 画一个圆环.( ...

  7. 浅谈一下关于使用css3来制作圆环进度条

    最近PC端项目要做一个这样的页面出来,其他的都很简单,关键在于百分比的圆环效果.我最初打算是直接使用canvas来实现的,因为canvas实现一个圆是很简便的. 下面贴出canvas实现圆环的代码,有 ...

  8. H5 可堆叠的圆环进度条,支持任意数量子进度条

    by Conmajia SN: S22-W1M 由来 看到一篇帖子<vue实用组件--圆环百分比进度条>,让我想起了很多年前我在WinForm下仿制过的Chrome进度条. ▲ 原版进度条 ...

  9. ios 画圆环进度条

    #import <UIKit/UIKit.h> @interface SNCircleProgressView : UIView /** * 进度值0-1.0之间 */ @property ...

随机推荐

  1. 【redis】pipeline - 管道模型

    redis-pipeline 2020-02-10: 因为我把github相关的wiki删了,所以导致破图...待解决.(讲真github-wiki跟project是2个url,真的不好用) 因为用的 ...

  2. <packaging>pom</packaging>是什么意思

    <packaging>pom</packaging>是什么意思? 答: 以下配置<packaging>pom</packaging>的意思是使用mave ...

  3. SVN使用经验

    转载于:Svn发布项目 个人使用体验: 关于svn的相关命令 从服务器检出创建的项目文件夹,向项目中添加文件,右键tortoiseSvn->add 然后右键SVN Commit,选择文件并输入提 ...

  4. python数据类型(总结篇)

    世界上最容易的事是坚持,最难的事也是坚持.开通博客园已两月有余,但实际上笔者本人的活跃度非常低,痛定思痛,自己选的路含泪也要走下去,继续坚持! 本文承接前几个月的python数据类型系列,完成对字典与 ...

  5. 止损+TS

    单策略单品种单策略多品种多策略单品种和加仓多策略多品种静态仓位和动态仓位 金肯特钠(kingKeltner)布林强盗(BollingerBandit)动态突破(DynamicBreakOutII)恒温 ...

  6. JSP+Servlet+Ajax实现用户增删改查的例子

    一.数据库设计 用户表User 已有的测试数据 二.Java代码编写 Java EE的架构一般分为以下五层: ①.Domain ②.DAO ③.Service ④.Controller ⑤.View ...

  7. pycharm导入python包

    总步骤:file --> settings --> poject interpreter --> 点击加号 --> 搜索需要导入的python包 --> 选中需要导入的p ...

  8. Vue开发环境跨域访问

    Vue开发环境跨域访问其他服务器或者本机其他端口,需要配置项目中config/index.js文件,修改如下 module.exports = { dev: { // Paths assetsSubD ...

  9. 【database】复制表数据到相同备份表

    目的及由来,因为数据库表都采取逻辑删除isDeleted=true/flase,但是之前有些报表或者其他的sql并没有在sql中指明此条件.为了不影响之前代码,所以: 1.数据库中创建一张相同的表,把 ...

  10. ASP.NET Core SignalR 使用

    SignalR: 实时 Web 功能使服务器端代码能够即时将内容推送到客户端(包括B/S,C/S,Andriod).   SignalR最新版本为3.0(截止2020-02-28)   SignalR ...