如何用纯 CSS 创作条形图,不用任何图表库

效果预览
按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。
https://codepen.io/zhang-ou/pen/XqzGLp
可交互视频教程
此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。
请用 chrome, safari, edge 打开观看。
源代码下载
请从 github 下载。
https://github.com/comehope/front-end-daily-challenges/tree/master/015-development-skills-card
代码解读
定义 dom,最外层的容器是卡片,内含一个标题,和一个技能说明,分别描述技能的名称和级别:
<div class="card">
    <h2>Development Skills</h2>
    <p class="skill html">
        <span>HTML5</span>
        <span class="level">90%</span>
    </p>
</div>
居中显示:
html, body {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(dimgray, silver, silver, dimgray);
}
技能卡片布局:
.card {
    width: 400px;
    background: linear-gradient(#333, dimgray);
    box-sizing: border-box;
    padding: 20px;
    font-family: sans-serif;
    color: white;
    letter-spacing: 0.1em;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);
}
文字布局:
.card h2 {
    text-transform: uppercase;
    text-align: center;
}
.card .skill {
    height: 50px;
}
.card .skill span {
    display: block;
}
.card .skill .level {
    transform: translateY(-1em);
    text-align: right;
}
用伪元素画出条形图:
.card .skill .level {
    position: relative;
}
.card .skill .level::before,
.card .skill .level::after {
    content: '';
    position: absolute;
    top: 1.2em;
    left: 0;
    width: 100%;
    height: 100%;
}
.card .skill .level::before {
    border: 1px solid mediumspringgreen;
    border-radius: 0.2em;
    height: 105%;
}
.card .skill .level::after {
    background-image: linear-gradient(to right, mediumspringgreen, mediumspringgreen);
    background-repeat: no-repeat;
    background-position: top 0.1em left 0.1em;
}
设置条形图的填充比例:
.card .skill.html .level::after {
    background-size: 90% 1em;
}
dom 增加多个技能,每个技能用命名不同的样式类:
<div class="card">
    <h2>Development Skills</h2>
    <p class="skill html">
        <span>HTML</span>
        <span class="level">90%</span>
    </p>
    <p class="skill css">
        <span>CSS</span>
        <span class="level">95%</span>
    </p>
    <p class="skill javascript">
        <span>JavaScript</span>
        <span class="level">80%</span>
    </p>
    <p class="skill svg">
        <span>SVG</span>
        <span class="level">60%</span>
    </p>
    <p class="skill canvas">
        <span>Canvas</span>
        <span class="level">75%</span>
    </p>
</div>
分别定义每个技能的条形图宽度:
.card .skill.css .level::after {
    background-size: 95% 1em;
}
.card .skill.js .level::after {
    background-size: 80% 1em;
}
.card .skill.svg .level::after {
    background-size: 60% 1em;
}
.card .skill.vue .level::after {
    background-size: 75% 1em;
}
最后,增加一点交互效果:
.card .skill:hover {
    background-color: #333;
}
大功告成!
知识点
- linear-gradient() https://developer.mozilla.org/en-US/docs/Web/CSS/linear-gradient
- translateY() https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/translateY
- background-image https://developer.mozilla.org/en-US/docs/Web/CSS/background-image
- background-repeat https://developer.mozilla.org/en-US/docs/Web/CSS/background-repeat
- background-position https://developer.mozilla.org/en-US/docs/Web/CSS/background-position
- background-size https://developer.mozilla.org/en-US/docs/Web/CSS/background-size
原文地址:https://segmentfault.com/a/1190000014768534
如何用纯 CSS 创作条形图,不用任何图表库的更多相关文章
- 15.纯 CSS 创作条形图,不用任何图表库
		原文代码:https://segmentfault.com/a/1190000014768534#articleHeader1 HTML代码: <html> <head> &l ... 
- 如何用纯 CSS 创作文本滑动特效的 UI 界面
		效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/QrxxaW 可交互视频教 ... 
- 如何用纯 CSS 创作一种有削铁如泥感觉的菜单导航特效
		效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/XqYroe 可交互视频教 ... 
- 如何用纯 CSS 创作 404 文字变形为 NON 文字的交互特效
		效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/ZoxjXm 可交互视频教 ... 
- 如何用纯 CSS 创作炫酷的同心矩形旋转动画
		效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/bMvbRp 可交互视频教 ... 
- 如何用纯 CSS 创作一个渐变色动画边框
		效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/odpRKX 可交互视频教 ... 
- 如何用纯 CSS 创作一种侧立图书的特效
		效果预览 在线演示 按下右侧的"点击预览"按钮在当前页面预览,点击链接全屏预览. https://codepen.io/zhang-ou/pen/deVgRM 可交互视频教程 此视 ... 
- 如何用纯 CSS 创作一个冒着热气的咖啡杯
		效果预览 在线演示 按下右侧的"点击预览"按钮在当前页面预览,点击链接全屏预览. https://codepen.io/zhang-ou/pen/xjXxoz 可交互视频教程 此视 ... 
- 如何用纯 CSS 创作一种文字断开的交互特效
		效果预览 在线演示 按下右侧的"点击预览"按钮在当前页面预览,点击链接全屏预览. https://codepen.io/zhang-ou/pen/LmjNgL 可交互视频教程 此视 ... 
随机推荐
- firewall-cmd 使用总结
			firewalld的简要说明: firewalld .firewall-cmd .firewall-offline-cmd它们Python脚本,通过定义的在/usr/lib/firewalld下面的x ... 
- Cloudera Manager架构原理
			cloudera manager的核心是管理服务器,该服务器承载管理控制台的Web服务器和应用程序逻辑,并负责安装软件,配置,启动和停止服务,以及管理上的服务运行群集. Cloudera Manage ... 
- POJ 1151 Atlantis(扫描线)
			题目原链接:http://poj.org/problem?id=1151 题目中文翻译: POJ 1151 Atlantis Time Limit: 1000MS Memory Limit: 10 ... 
- jvm 实战
			https://blog.csdn.net/neutrojan/article/details/50532590# 1.ps -ef |grep java 找出最耗性能的JAVA进程2.top -Hp ... 
- set+线段树 Codeforces Round #305 (Div. 2) D. Mike and Feet
			题目传送门 /* 题意:对于长度为x的子序列,每个序列存放为最小值,输出长度为x的子序列的最大值 set+线段树:线段树每个结点存放长度为rt的最大值,更新:先升序排序,逐个添加到set中 查找左右相 ... 
- sublime text 3 文件列表忽略特定格式的文件
			Preferences->Settings ,编辑相关代码,注意JSON格式: 排除特定目录,使用:"folder_exclude_patterns" 排除特定文件,使用:& ... 
- Could not open logfile" occurred when run "datapatch -verbose"
			CAUSE Due to Bug 25459405 - DATAPATCH FAILS WITH SP2-0768 IF NLS_LANGUAGE IS NOT SET TO AMERICANwhic ... 
- UVa OJ 458
			The Decoder Write a complete program that will correctly decode a set of characters into a valid m ... 
- hihocoder offer收割编程练习赛8 A 小Ho的强迫症
			思路: 乱搞. 实现: #include <iostream> #include <cstdio> using namespace std; typedef long long ... 
- android AutoCompleteTextView 实现手机号格式化,附带清空历史的操作
			有个小伙伴遇到了这样一个问题,就是AutoCompleteTextView实现自动填充的功能.同时要具备手机格式化的功能.下拉列表最后一行是有个清除历史的功能.可是点击“清除历史”却把文字要设置进去A ... 
