京公网安备 11010802034615号
经营许可证编号:京B2-20210330
经常听到大家在讨论D3怎么怎么样,小编还很好奇D3是什么,今天终于了解到了。下面小编就带大家一起来看,到底什么是D3.用它能做什么吧。
一、D3概念
D3 的全称为:Data-Driven Documents,实质上就是一个被数据驱动的文档。通俗来理解,其实就是一个开源的JavaScript 的函数库,我们通常用它来做数据可视化的。D3 可以让设计师通过SVG这种常见的图形格式进行创作,因此对于设计师来说,D3 很是方便快捷。而且对于程序员来说,D3 也很合适,因为它是兼容Web标准的。
具体的官方介绍大家可以查看D3官网:https://d3js.org
二、D3优点
1.D3是完全开放的,我们可以免费使用D3制作一些娱乐或者赚钱的东西,甚至不用提到D3的名字;
2.Google Chrome、Mozilla Firefox、Opera、Safari和Internet Explorer 9及其以上版本的浏览器都兼容D3.
3.D3基于现有的Web标准的HTML和SVG就能有强大的数据可视化功能,根本不需要依赖任何第三方插件或专属框架。
4.D3与数据相结合,能够提供一种可以直接操作Web的内置场景结构,也就是文档对象模型的方式。
5.D3能够直接在SVG这种Web文档格式的图形元素上根据数据值来设置属性。
下面来举一个D3绘制饼状图的例子,给大家展示D3强大的数据可视化功能。
1.data.csv文件,使用键值对的形式进行书写
education,population 大专及以上,11964 高中和中专,18799 初中,51966 小学,35876 文盲人口,5466
2.html代码
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
<div id="container"></div>
</body>
<script type="text/javascript" src="js/d3.js" ></script>
<script type="text/javascript" src="js/pinzhuangtu.js" ></script>
</html>
3.js代码实现饼状图
d3.csv("data.csv",type,function(data){
width = 400,
height = 400;
var svg = d3.select("#container")
.append("svg")
.attr({
"width":width,
"height":height
})
var g = svg.append("g")
.attr("transform","translate(200, 200)")
var arc_generator = d3.svg.arc()
.innerRadius(100)//设置内半径
.outerRadius(200)//设置外半径
var angle_data = d3.layout.pie()
.value(function(d){return d.population;})
console.log(angle_data(data));
var color = d3.scale.category10();
g.selectAll("path")
.data(angle_data(data))
.enter()
.append("path")
.attr("d", arc_generator)
.style("fill",function(d,i){return color(i)})//给不同的扇形区填充不同的颜色
g.selectAll("text")//给每个扇形去添加对应文字
.data(angle_data(data))
.enter()
.append("text")
.text(function(d){return d.data.education})
.attr("transform",function(d){return "translate("+arc_generator.centroid(d)+")"})//调成每个文字的对应位置
.attr("text-anchor","middle")//是文字居中
});
function type(d) {
d.population =+ d.population;
return d;
}
看到这里,大家是不是对D3的可视化功能给惊艳到了呢!肯定有很多小伙伴都想要学习使用D3了吧,但是学习和使用D3还是有一定难度的,尤其是对于像小编一样的编程小白来说。因此在学习D3之前我们还必须要掌握一些编程方面的具体知识,主要涉及到以下几个方面:
1.HTML,也就是超文本标记语言,通常被用来设定网页的内容
2.CSS,即层叠样式表,通常被用来设定网页的样式
JavaScript,一种直译式脚本语言,我们通过它来设定网页的行为
DOM,所谓的文档对象模型,使用它对文档的内容和结构进行修改
SVG,就是可缩放矢量图形,往往被用于绘制可视化的图形
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
在分类变量关联分析中(如 “吸烟与肺癌的关系”“性别与疾病发病率的关联”),卡方检验 P 值与 OR 值(比值比,Odds Ratio)是 ...
2025-11-05CDA 数据分析师的核心价值,不在于复杂的模型公式,而在于将数据转化为可落地的商业行动。脱离业务场景的分析只是 “纸上谈兵” ...
2025-11-05教材入口:https://edu.cda.cn/goods/show/3151 “纲举目张,执本末从。” 若想在数据分析领域有所收获,一套合适的学习教材至 ...
2025-11-05教材入口:https://edu.cda.cn/goods/show/3151 “纲举目张,执本末从。” 若想在数据分析领域有所收获,一套合适的学习教材至 ...
2025-11-04【2025最新版】CDA考试教材:CDA教材一级:商业数据分析(2025)__商业数据分析_cda教材_考试教材 (cdaglobal.com) ...
2025-11-04在数字化时代,数据挖掘不再是实验室里的技术探索,而是驱动商业决策的核心能力 —— 它能从海量数据中挖掘出 “降低成本、提升 ...
2025-11-04在 DDPM(Denoising Diffusion Probabilistic Models)训练过程中,开发者最常困惑的问题莫过于:“我的模型 loss 降到多少才算 ...
2025-11-04在 CDA(Certified Data Analyst)数据分析师的工作中,“无监督样本分组” 是高频需求 —— 例如 “将用户按行为特征分为高价值 ...
2025-11-04当沃尔玛数据分析师首次发现 “啤酒与尿布” 的高频共现规律时,他们揭开了数据挖掘最迷人的面纱 —— 那些隐藏在消费行为背后 ...
2025-11-03这个问题精准切中了配对样本统计检验的核心差异点,理解二者区别是避免统计方法误用的关键。核心结论是:stats.ttest_rel(配对 ...
2025-11-03在 CDA(Certified Data Analyst)数据分析师的工作中,“高维数据的潜在规律挖掘” 是进阶需求 —— 例如用户行为包含 “浏览次 ...
2025-11-03在 MySQL 数据查询中,“按顺序计数” 是高频需求 —— 例如 “统计近 7 天每日订单量”“按用户 ID 顺序展示消费记录”“按产品 ...
2025-10-31在数据分析中,“累计百分比” 是衡量 “部分与整体关系” 的核心指标 —— 它通过 “逐步累加的占比”,直观呈现数据的分布特征 ...
2025-10-31在 CDA(Certified Data Analyst)数据分析师的工作中,“二分类预测” 是高频需求 —— 例如 “预测用户是否会流失”“判断客户 ...
2025-10-31在 MySQL 实际应用中,“频繁写入同一表” 是常见场景 —— 如实时日志存储(用户操作日志、系统运行日志)、高频交易记录(支付 ...
2025-10-30为帮助教育工作者、研究者科学分析 “班级规模” 与 “平均成绩” 的关联关系,我将从相关系数的核心定义与类型切入,详解 “数 ...
2025-10-30对 CDA(Certified Data Analyst)数据分析师而言,“相关系数” 不是简单的数字计算,而是 “从业务问题出发,量化变量间关联强 ...
2025-10-30在构建前向神经网络(Feedforward Neural Network,简称 FNN)时,“隐藏层数目设多少?每个隐藏层该放多少个神经元?” 是每个 ...
2025-10-29这个问题切中了 Excel 用户的常见困惑 —— 将 “数据可视化工具” 与 “数据挖掘算法” 的功能边界混淆。核心结论是:Excel 透 ...
2025-10-29在 CDA(Certified Data Analyst)数据分析师的工作中,“多组数据差异验证” 是高频需求 —— 例如 “3 家门店的销售额是否有显 ...
2025-10-29