iis服务器助手广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >仅使用一个div配合css实现饼状图的方法
  • 701
分享到

仅使用一个div配合css实现饼状图的方法

2024-04-02 19:04:59 701人浏览 安东尼
摘要

本篇内容主要讲解“仅使用一个div配合CSS实现饼状图的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“仅使用一个div配合css实现饼状图的方法”吧!完整的

本篇内容主要讲解“仅使用一个div配合CSS实现饼状图的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“仅使用一个div配合css实现饼状图的方法”吧!

仅使用一个div配合css实现饼状图的方法

完整的代码请滑到文末。

我们只使用一个div,仅采用css实现饼状图。

html 结构

<div class="pie" style="--p:60;--b:10px;--c:purple;">60%</div>

我们添加了几个 css 的变量:

  • --p:进度条的百分比(纯数字,不带%),饼状图值和 div 内容(带%)一致。

  • --b:边框厚度的值

  • --c:边框的主体颜色

本文使用的是简写的变量,在生产环境中,为了达到可读性,我们应该使用--p -> --percentage, --b -> --border-thickness, --c -> --main-color 来表示。

Pie 的基本设置

我们为饼状图设定基本的样式。

.pie {
  --w: 150px; // --w -> --width
  width: var(--w);
  aspect-ratio: 1; // 纵横比,1 说明是正方形
  display: inline-grid;
  place-content: center;
  margin: 5px;
  font-size: 25px;
  font-weight: bold;
  font-family: sans-serif;
}

上面我们使用了 aspect-ratio: 1; 保证 div 是正方形,当然你也可以使用 height: var(--w) 达到效果。

接下来,我们使用伪元素实现简单的饼状图:

.pie:before {
  content: "",
  position: absoute;
  border-radius: 50%;
  inset: 0; // 知识点 1
  background: conic-gradient(var(--c) calc(var(--p)*1%),#0000 0); // 知识点 2
}

知识点1: inset: 0; 相当于 top: 0; right: 0; bottom: 0; top: 0;

知识点2: conic-gradient 圆锥渐变,css 方法, 更多内容, 这里的 #0000 是 transparent 的十六进制。

#0000 Hex Color · Red (0%) · Green (0%) · Blue (0%).

conic-gradient应用之后:

仅使用一个div配合css实现饼状图的方法

为了使得仅是边框的区域被看到,我们使用 mask 属性去隐藏中间圆的部分。我们将使用 radial-gradient() 方法:

radial-gradient(farthest-side,red calc(99% - var(--b)),blue calc(100% - var(--b)))

上面代码应用后,可得到效果图如下:

仅使用一个div配合css实现饼状图的方法

我们的目标如下图:

仅使用一个div配合css实现饼状图的方法

我们更改下代码即可实现:

<div class="pie" style="--p:60;--b:10px;--c:purple;">60%</div>
.pie {
  --w:150px;
  
  width: var(--w);
  aspect-ratio: 1;
  position: relative;
  display: inline-grid;
  place-content: center;
  margin: 5px;
  font-size: 25px;
  font-weight: bold;
  font-family: sans-serif;
}
.pie:before {
  content: "";
  position: absolute;
  border-radius: 50%;
  inset: 0;
  background: conic-gradient(var(--c) calc(var(--p)*1%),#0000 0);
  -WEBkit-mask:radial-gradient(farthest-side,#0000 calc(99% - var(--b)),#000 calc(100% - var(--b)));
          mask:radial-gradient(farthest-side,#0000 calc(99% - var(--b)),#000 calc(100% - var(--b)));
}

添加圆形边缘

如何添加圆形边缘呢,看了下面插图,你就明白这个小技巧。

仅使用一个div配合css实现饼状图的方法

针对图上的效果(1),是将圆形放在开始的边缘。

.pie:before {
  background: 
    radial-gradient(farthest-side, var(--c) 98%, #0000) top/var(--b) var(--b) no-repeat,
    conic-gradient(var(--c) calc(var(--p)*1%), #0000 0);
}

针对图上的效果(2),是将圆形放在结束的边缘。

.pipe: after {
  content: "";
  position: absolute;
  border-radius: 50%;
  inset: calc(50% - var(--b)/2); // 知识点1
  background: var(--c);
  transfORM: rotate(calc(var(--p)*3.6deg)) translateY(calc(50% - var(--w)/2)); // 知识点2
}

知识点1: 的 inset: 0; 上面我们也提到 -- 它是 left: 0; right: 0; bottom: 0; top: 0; 的简写。

这里我们有:

left = right = 50% - b/2

这里我们将元素往左和右移动了50% - b/2,也就等于元素宽度为 b, 且左右居中。针对高度,同理。

知识点2: 的旋转度数计算 --

angle = percentage * 360deg / 100

先将元素旋转了相应的度数,之后对其位置进行移动,这里涉及到了对 Y 轴居中。看文字也许有些难懂,结合下面的插图理解下:

仅使用一个div配合css实现饼状图的方法

添加动画

到现在为止,我们实现的是一个静止的饼状图。我们接下来为它加上动效。

先注册变量:

@property --p {
  syntax: '<number>';
  inherits: true;
  initial-value: 0;
}

接着,我们创建关键帧:

@keyframes p {
  from {
    --p: 0
  }
}

注意:这里我们只需要设置 from 的 --p 值即可。浏览器会自动匹配我们预设 to 中的值(div class="pie" style="--p:60;">60%</div>)

最后,我们调用动画。

animation: p 1s .5s both;

嘿嘿~ 复制下面的代码体验一下吧。当然,我们也提供了图。

代码和效果图

<div class="pie" style="--p:20"> 20%</div>
<div class="pie" style="--p:40;--c:darkblue;--b:10px"> 40%</div>
<div class="pie no-round" style="--p:60;--c:purple;--b:15px"> 60%</div>
<div class="pie animate no-round" style="--p:80;--c:orange;"> 80%</div>
<div class="pie animate" style="--p:90;--c:lightgreen"> 90%</div>
@property --p{
  syntax: '<number>';
  inherits: true;
  initial-value: 1;
}
.pie {
  --p:20;
  --b:22px;
  --c:darkred;
  --w:150px;
  width: var(--w);
  aspect-ratio: 1;
  position: relative;
  display: inline-grid;
  margin: 5px;
  place-content: center;
  font-size: 25px;
  font-weight: bold;
  font-family: sans-serif;
}
.pie:before,
.pie:after {
  content: "";
  position: absolute;
  border-radius: 50%;
}
.pie:before {
  inset: 0;
  background:
    radial-gradient(farthest-side,var(--c) 98%,#0000) top/var(--b) var(--b) no-repeat,
    conic-gradient(var(--c) calc(var(--p)*1%),#0000 0);
  -webkit-mask: radial-gradient(farthest-side,#0000 calc(99% - var(--b)),#000 calc(100% - var(--b)));
          mask: radial-gradient(farthest-side,#0000 calc(99% - var(--b)),#000 calc(100% - var(--b)));
}
.pie:after {
  inset: calc(50% - var(--b)/2);
  background: var(--c);
  transform: rotate(calc(var(--p)*3.6deg)) translateY(calc(50% - var(--w)/2));
}
.animate {
  animation: p 1s .5s both;
}
.no-round:before {
  background-size: 0 0, auto;
}
.no-round:after {
  content: none;
}
@keyframes p{
  from{--p:0}
}

效果图:

仅使用一个div配合css实现饼状图的方法

到此,相信大家对“仅使用一个div配合css实现饼状图的方法”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: 仅使用一个div配合css实现饼状图的方法

本文链接: https://www.lsjlt.com/news/88773.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 仅使用一个div配合css实现饼状图的方法
    本篇内容主要讲解“仅使用一个div配合css实现饼状图的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“仅使用一个div配合css实现饼状图的方法”吧!完整的...
    99+
    2024-04-02
  • 怎么使用纯CSS实现饼状图
    这篇文章主要介绍“怎么使用纯CSS实现饼状图”,在日常操作中,相信很多人在怎么使用纯CSS实现饼状图问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答...
    99+
    2024-04-02
  • iOS中UIBezierPath实现饼状图的方法
    这篇文章主要介绍iOS中UIBezierPath实现饼状图的方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!首先看效果图:代码:#import <UIKit/UIKit.h> NS_...
    99+
    2023-06-14
  • 使用CSS怎么实现一个三角形和饼图
    使用CSS怎么实现一个三角形和饼图?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 .triangle{width:0;height:0;border-width:...
    99+
    2023-06-08
  • 怎么在html5中使用canvas实现一个动态画饼状图
    怎么在html5中使用canvas实现一个动态画饼状图?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。先用canvas画实心圆//伪代码var canv...
    99+
    2023-06-09
  • 如何使用纯CSS实现饼状Loading等待图效果
    这篇文章将为大家详细讲解有关如何使用纯CSS实现饼状Loading等待图效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。效果图:原理这个东西分为两部分:外圈和内圆。颜色这东西都自定义啦,不过我画的的圈圈...
    99+
    2023-06-08
  • 如何使用单div实现CSS绘图方法
    本篇内容主要讲解“如何使用单div实现CSS绘图方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用单div实现CSS绘图方法”吧! ...
    99+
    2024-04-02
  • html5中如何使用canvas封装一个echarts实现不了的饼图
    这篇文章主要介绍html5中如何使用canvas封装一个echarts实现不了的饼图,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!说明我用echars很久了,如果出现如上图所示样式的饼图,我用echarts很难实现,...
    99+
    2023-06-09
  • css实现图片大于div时的居中显示的方法
    本文小编为大家详细介绍“css实现图片大于div时的居中显示的方法”,内容详细,步骤清晰,细节处理妥当,希望这篇“css实现图片大于div时的居中显示的方法”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深...
    99+
    2024-04-02
  • 使用CSS怎么实现一个图片动画特效
    本篇文章给大家分享的是有关使用CSS怎么实现一个图片动画特效,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。HTML代码<!-- 主容器 -->&...
    99+
    2023-06-08
  • Dreamweaver使用通配符批量替换某个div的方法
    这篇文章主要讲解了“Dreamweaver使用通配符批量替换某个div的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Dreamweaver使用通配符批量替换某个div的方法”吧!如希望...
    99+
    2023-06-08
  • 如何使用css实现一个大太阳的天气图标
    小编给大家分享一下如何使用css实现一个大太阳的天气图标,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!效果效果图如下实现思路di...
    99+
    2024-04-02
  • 一个简单的toolabar结合drawlayout使用方法
    本文实例为大家分享了toolabar结合drawlayout使用方法,供大家参考,具体内容如下package alice.bw.com.day03toolabardrawlayout;import android.support.v7.ap...
    99+
    2023-05-30
    toolabar drawlayout
  • 如何使用纯CSS实现单一div的正多边形变换
    这篇文章给大家分享的是有关如何使用纯CSS实现单一div的正多边形变换的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。   纯粹利用CSS,让“单一个”div,从正三角形变换为正...
    99+
    2024-04-02
  • 一个Activity中多个Fragment实现沉浸式状态栏的解决方法
    项目中遇到一个问题:一个Activity有多个Fragment,每个Fragment的沉浸式状态栏不一样,有的是红色,有的是黑色,有的是一张图片(图片的一部分在状态栏中显示),并且要要兼顾虚拟按键(常说的导航栏)遮盖住布局导致自己布局中的某...
    99+
    2023-05-31
    fragment 沉浸式 状态栏
  • 怎么用CSS实现美观大方的网页柱状图效果
    这篇文章主要介绍“怎么用CSS实现美观大方的网页柱状图效果”,在日常操作中,相信很多人在怎么用CSS实现美观大方的网页柱状图效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2024-04-02
  • 浅析css隐藏div块的实现方法和应用场景
    CSS的隐藏功能在网页设计中起着重要的作用,尤其是在实现动态效果的过程中。在这个过程中,隐藏Div块是经常用到的一种方法。本文将为大家介绍CSS隐藏Div块的实现方法和应用场景。一、CSS隐藏Div块的实现方法display属性displa...
    99+
    2023-05-14
  • 怎么用纯CSS实现一个足球场的俯视图
    这篇文章主要为大家展示了“怎么用纯CSS实现一个足球场的俯视图”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么用纯CSS实现一个足球场的俯视图”这篇文章吧。 ...
    99+
    2024-04-02
  • Nginx同一个域名配置多个项目的实现方法
    使用Nginx要在同一个域名下配置多个项目有两种方式: nginx按不同的目录分发给不同的项目 启用二级域名,不同的项目分配不同的二级域名 1.nginx按不同的目录分发...
    99+
    2024-04-02
  • Java实现把两个数组合并为一个的方法总结
    本文实例讲述了Java实现把两个数组合并为一个的方法。分享给大家供大家参考,具体如下:在Java中,如何把两个String[]合并为一个?看起来是一个很简单的问题。但是如何才能把代码写得高效简洁,却还是值得思考的。这里介绍四种方法,请参考选...
    99+
    2023-05-30
    java 数组合并 ava
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作