千家信息网

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

发表于:2025-01-16 作者:千家信息网编辑
千家信息网最后更新 2025年01月16日,本篇内容主要讲解"仅使用一个div配合css实现饼状图的方法",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"仅使用一个div配合css实现饼状图的方法"吧!
千家信息网最后更新 2025年01月16日仅使用一个div配合css实现饼状图的方法

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

完整的代码请滑到文末。

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

HTMl 结构

60%

我们添加了几个 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应用之后:

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

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

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

我们的目标如下图:

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

60%
.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)));}

添加圆形边缘

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

针对图上的效果(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 轴居中。看文字也许有些难懂,结合下面的插图理解下:

添加动画

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

先注册变量:

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

接着,我们创建关键帧:

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

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

最后,我们调用动画。

animation: p 1s .5s both;

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

代码和效果图

20%
40%
60%
80%
90%
@property --p{  syntax: '';  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实现饼状图的方法"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

知识 知识点 方法 效果 代码 元素 内容 圆形 边缘 变量 效果图 边框 接下来 动画 度数 插图 更多 正方 正方形 简写 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 计算机软件开发工资高吗贴吧 计算机网络技术在铁路上的应用 暑期网络安全手抄报图片 巩义市蝶变网络技术有限公司 桂林地名数据库 软件开发自由职业者工资 网络技术部可以看见手机下载 浙江智慧团建软件开发公司 什么是数据库的事务 sql数据库db文件 军用网络安全龙头股 软件开发培训心得体会怎么写 大专生游戏软件开发 数据库表的主键外键有什么作用 数据库技术建议书 coc兵升级数据库7本 博尔塔拉软件开发简介 服务器怎么打补丁安全模式 国际网络安全问题有哪些 上海app软件开发外包 牟平区管理系统软件开发解决方案 Cisco服务器怎么多接端口 魔兽世界9.1服务器维护时间 县气象局网络安全承诺书 德惠通用网络技术服务共同合作 什么是数据库的事务 flask 数据库连接 山西税务局网络安全文件 琉璃日月怎么进别人服务器 易语言如何断开数据库链接
0