当前位置: 首页 > news >正文

D3.js 与数据可视化

数据可视化工具简介

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

D3.js = a JavaScript library

  • D3.js 是一个开源的JavaScript库: https://github.com/d3/d3
  • D3.js提供了很多可视化函数。

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。

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

  • D3图片库: https://d3-graph-gallery.com/
  • React图片库: https://www.react-graph-gallery.com/
  • 未完待续 …
http://www.dtcms.com/a/398426.html

相关文章:

  • RNA-seq分析之最佳cutoff(TCGA版)
  • 浏览器直接进入网站的注意事项钢筋网片价格
  • scrapy-redis项目:爬取某网站图书信息
  • (论文速读)DiffBlender:可组合和通用的多模态文本到图像扩散模型
  • 第三方网站测试工具:【Postman使用基础指南】
  • Pytest+requests进行接口自动化测试5.0(5种assert断言的封装 + pymysql)
  • C# MVC 模型绑定全解析:从基础机制到自定义绑定器实战指南
  • 企业网站网页设计专业的团队网站建设
  • 网站建设可上传视频的wordpress 数据库类型
  • 广州南沙区建设和交通局网站个人建立网站要多少钱
  • Vue3 》》vite》》vite-plugin-mock mock 模拟数据 ,loadEnv
  • 宝塔面板搭建RustDesk教程:告别命令行,一键拥有私有远程桌面
  • Docker + IDEA 一键部署!
  • Rust开源HyperSwitch实战指南
  • Chrome性能优化指南
  • Chrome高危类型混淆0-Day漏洞(CVE-2025-10585)技术分析
  • 教做面点的网站广州百度竞价托管
  • 网站推广方案合肥房产网安居客
  • 【算法专题训练】24、单调栈
  • 【开题答辩全过程】以 IRWT考试预约系统为例,包含答辩的问题和答案
  • 在字典和列表相互嵌套的结构体中搜索指定元素
  • 文献阅读 | iMetaMed | FigureYa:一个标准化可视化框架,用于增强生物医学数据解释和研究效率
  • wordpress自由拖拽同ip网站做排名seo
  • 面向运动障碍患者的语音识别新突破:零样本实时专家混合自适应方法详解
  • 校园网站建设的维护制作触屏版网站开发
  • 零衍门户组件联邦模式:重新定义组件开发新体验!
  • 【Web前端|第一篇】HTML、CSS与JavaScript
  • 有手机网站了还要微网站吗所有的网站都要用htmlu做吗
  • 面向对象设计:构建可维护、可扩展的软件系统
  • 52.haproxy负载均衡