D3.js 与数据可视化

数据可视化工具简介

就像单反vs手机照相机一样,越复杂越强大。把数据可视化工具按照复杂程度排序,最右端是D3.js,它最强大,也最难学!

D3.js = a JavaScript library

D3.js ≠ a dataviz library

但是,都是底层代码,不直接面向用户,比如没有: boxplot() or scatterplot() 直接出图的函数。

它提供的是辅助函数,核心是:你要手动绘图。

  • 遍历数据,计算X和Y位置,画出每个点;
  • 绘制X轴:线 + tick + label,同理Y轴;
  • 添加标题: 使用 html p标签
  • 需要 tooltip? 需要更多代码

D3.js不直接绘图,但是提供了强大的工具:

  • scale() 计算圆圈位置
  • ticks() 找到轴上刻度位置
  • ...

这里提供一个交互式沙箱,最简单的散点图:https://www.react-graph-gallery.com/scatter-plot#circles

D3.js = powerful, but hard

自己手工构建所有东西 - 包括交互。而不局限于:如果这个库有这个选项。

缺点?需要花很多时间学习。所有都自己写很强大,但对能力要求也高。

这是一个小项目,展示如何使用D3创建自定义:https://www.react-graph-gallery.com/example/radar-chart-animation

直到现在,相对于D3,其他工具显得很局限,限制很多。

The web is split

很重要、很困惑的点:

  • 之前很长时间,人们用纯js构建网站,一切正常。
  • 但是最近15年,Facebook推出一个UI库叫React改变了一切!它解决了开发者很多头疼的问题,并成为了标准。
  • 而你使用React(或者 Vue,Svelte),D3中2/3不是必须的。

这决定着你怎么学D3。

如果按照过时教程,你将花很多时间学习以后再也用不到的内容。

  • 未完待续 ...
相关推荐
liangshanbo12159 分钟前
React 19 vs React 18全面对比
前端·javascript·react.js
Never_Satisfied24 分钟前
在 JavaScript 中,删除数组中内容为xxx的元素
java·前端·javascript
_菜鸟果果25 分钟前
Vue3+echarts 3d饼图
前端·javascript·echarts
mjhcsp41 分钟前
MATLAB 疑难问题诊疗:从常见报错到深度优化的全流程指南
开发语言·matlab
Lynnxiaowen1 小时前
今天我们开始学习python语句和模块
linux·运维·开发语言·python·学习
逐步前行1 小时前
C标准库--浮点<float.h>
c语言·开发语言
zoyation1 小时前
多线程简介和在JAVA中应用
java·开发语言
余辉zmh1 小时前
【C++篇】:ServiceBus RPC 分布式服务总线框架项目
开发语言·c++·rpc
rechol1 小时前
类与对象(中)笔记整理
java·javascript·笔记
Luffe船长1 小时前
前端vue2+js+springboot实现excle导入优化
前端·javascript·spring boot