JavaScript

d3.js 基础 - 一个数据可视化相关的 javascript

2016-08-16  本文已影响368人  HeyDelilah

2016-04-07

本文谈谈 d3 中的数据绑定、scale、坐标轴。

一、d3.js 介绍

1. d3 是什么?

d3.js 是一个用于制作数据可视化相关的 javascript 工具库,你可以在 d3.js 官网 中找到数之不尽的、使用 d3 绘制的精美数据可视化图像。

d3.js 是基于 svg 的函数库,(其实也支持 canvas,但 api 不够丰富)

2. 为什么要使用 d3 ?

若你的项目是数据相关的,且需要大量定制化的图表时,d3.js 会是一个很好的选择。

曾使用过 highchart.js , echart.js(百度),这两者都是很好的图表库,可满足于常见的通用图表,如柱状图、饼图、折线图、地图等等。但无论是 highchart 还是 echart,这类图表库能提供的图表毕竟是有限的,即便它们提供的图表越来越丰富(如也涵盖了许多高级复杂图表)、灵活性(可配置项)越来越高,但无法随心所欲,绘制出你天马星空的所思所想。

3. 一个标准、常见的 d3.js 操作流程如下:

d3.select(".chart")
    // 若 .chart 下没有任何 div, 返回空数组
    .selectAll("div")

    // 数据绑定
    .data(data)

    // 此刻返回的是一系列占位符
    .enter()

    // 插入 DOM 结点
    .append("div")

    // 设置样式
    .style("width", function(d) { return d * 10 + "px"; })

    // 插入文字
    .text(function(d) { return d; });

其核心包括:选择器,数据绑定,DOM 操作,样式与文字;

二、选择器

三、数据绑定

d3 在处理数据方面,有三种状态,enter(), exit() 和 update。

缺省状态下,d3 根据序号(index)来进行数据绑定
data-join.png

将 elements 与数据集(datas),一对对拿出来看:(elements 对应于 d3 渲染在页面上的 dom 结点。)

指定了参照值的情况下:(即在调用 .data() 绑定数据时,再传入 key function 指定特定的 key )

elements 内部属性 data 中存的值与实际 data 对比,若:

constancy.png

与顺序无关

order.png

四、缩放 scale (或者翻译成 “比例尺”)

作用:将数据集与我们希望的视图大小映射起来,如 datas =[1,2,3],也许我们希望展现在屏幕中的是 [100px, 200px, 300px];

1. 连续的 - 如 [0, 100]

2. 离散的 - 即定义域和值域并非是连续变化的。如 ['A', 'B', 'C', 'D']

好玩之处

五、坐标轴

<g>, <line>, <text> 组成

六、资料

官网学习资料好齐全,讲解的也很赞。下面几篇基本都是从官网上找到链接的。

上一篇 下一篇

猜你喜欢

热点阅读