Learn D3 入门文档: By Example

本文介绍了使用D3.js的一个有效方法是通过研究示例库。通过修改现有示例,可以快速理解和学习D3的功能。文章以创建直方图为例,演示了如何导入D3直方图示例并替换数据,以及如何自定义图表样式。此外,还讨论了数据流的概念,当输入数据改变时,图表会自动更新。最后,鼓励读者尝试自己编写代码,进一步掌握D3。
摘要由CSDN通过智能技术生成

引子

Learn D3: Introduction 第二篇,只是英文翻译,可修改代码的部分用静态图片替代了,想要实时交互请阅读原文。

正文

开始使用 D3 的最佳方式之一是浏览示例库

如果你运气好(而且有很多选择,你的几率也不错),你可能会找到一个可以重新调整用途的示例。这可以节省学习如何从头开始构建的大量精力。例如,要构造一个 treemap ,你可以查询 d3 层次 API 索引 ,但更快的方法是获取 treemap 示例并替换你的数据。

这可能感觉像作弊,但没关系!👍 示例不仅是可重复使用的模板,也是学习工具,暗示着要学习的主题。”打破“一个例子,通过修补变化的东西,看看发生了什么,可以帮助你比被动阅读更快地理解。

另外,这很有趣。😺

并非巧合,Observable 旨在帮助你进行修补。访问任何笔记本,编辑一个单元格,看看会发生什么!在许多情况下,替换数据所需要的只是单击以替换文件。如果你喜欢这个结果,通过派生来保存你的工作。

你还可以导入示例并修改它们,而无需深入代码。毫无疑问,这是开始使用 D3 最快的方式,而且随着你的学习,它会变得更加强大。

让我们看看如何进行的。

假设我给你一组数字。关于这些数据,你能告诉我些什么?

87-1

你可以手动查看一些值,但这不会显示太多。无法知道你检查的少数值是否代表整个分布。如果你要通过引入 D3(版本6)来计算一些汇总统计数据,例如最小值、中值和最大值,该怎么办?

87-2
87-3

好吧,这很重要。但我们需要比单个数字更丰富的东西来获得分布感。

我们需要一个可视化。确切的说是直方图。因此,让我们导入直方图示例,并使用导入的 with 子句(Observable JavaScript 特有的特性)将数值数组 values 作为 data

87-4
87-5

瞧!现在我们看到:数据大致形成以零为中心的正态分布(我使用 d3.randomNormal 创建了这些值,预期值 μ=0,标准偏差 σ=1 。)

但我们并不局限于在导入时替换数据。我们可以覆盖任何单元格,比如自定义 x 或 y 轴的样式。或者,如果我们更喜欢高度略小的图表,我们可以重新定义高度。

87-6
87-7
87-8

在这张高度略小的图表中,您是否注意到沿 y 轴刻度较少?神奇!如果你认为这很酷,那么在我们注入动态数据时,看看这个直方图吧!单击下面的 “play” 或拖动滑块。

87-9
87-10

下面的 values3 单元格生成随机值,而 x 单元格将直方图的区域固定为 [-10,+10]。固定区域显示了分布如何随平均值 mu 的变化而变化;如果未指定固定区域,则将计算该区域以适配数据,并且只有通过仔细读取 x 轴刻度,分布的变化才会明显(要亲自查看,请尝试从以下导入的 with 子句中删除 x 。)

87-11
87-12
87-13

我们不需要重写直方图来激活它,因为引用 mu 的单元格,包括导入的单元格,在 mu 发生更改时会自动运行,这要归功于数据流

现在你已经看到了如何示例再利用,那么让我们从头开始编写一些代码吧!

Next

提取了上面一个示例的主要代码,做了一个静态的页面,见这里

参考资料

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Paperback: 280 pages Publisher: Packt Publishing - ebooks Account (February 1, 2016) Language: English ISBN-10: 1785280082 ISBN-13: 978-1785280085 Key Features Learn to use the facilities provided by D3.js to create data-driven visualizations Explore the concepts of D3.js through examples that enable you to quickly create visualizations including charts, network diagrams, and maps Get practical examples of visualizations using real-world data sets that show you how to use D3.js to visualize and interact with information to glean its underlying meaning Book Description This book will take you through all the concepts of D3.js starting with the most basic ones and progressively building on them in each chapter to expand your knowledge of D3.js. Starting with obtaining D3.js and creating simple data bindings to non-graphical HTML elements, you will then master the creation of graphical elements from data. You'll discover how to combine those elements into simple visualizations such as bar, line, and scatter charts, as well as more elaborate visualizations such as network diagrams, Sankey diagrams, maps, and choreopleths. Using practical examples provided, you will quickly get to grips with the features of D3.js and use this learning to create your own spectacular data visualizations with D3.js. What you will learn Install and use D3.js to create HTML elements within the document Use development tools such as JSBIN and Chrome Developer Tools to create D3.js applications Retrieve JSON data and use D3.js selections and data binding to create visual elements from data Create and style graphical elements such as circles, ellipses, rectangles, lines, paths, and text using SVG Turn your data into bar and scatter charts, and add margins, axes, labels, and legends Use D3.js generators to perform the magic of creating complex visualizations from data Add interactivity to your visualizations, including tool-tips, sorting, hover-to-highlight, and grouping and dragging of visuals
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值