小可爱的d3学习笔记

一、简介

1. D3是什么?

D3 (或D3.js) 是一个用来使用Web标准做数据可视化的JavaScript库。 D3帮助我们使用SVG, Canvas 和 HTML技术让数据生动有趣。 D3将强大的可视化,动态交互和数据驱动的DOM操作方法完美结合,让我们可以充分发挥现代浏览器的功能,自由的设计正确的可视化界面。

2. 我为什么用D3?

1)结合HTML,SVG,CSS,D3可以图形化的,生动的展现数据。是目前最流行的数据可视化库,同时是Github上前端库排行第二(仅次于bootstrap)。

2)比Processing这样的底层绘图库更简单,比Echarts这样高度封装的图表库更自由。

3.D3的下载和使用

D3官网

D3github地址 

4.D3有哪些功能?

行为 - 可重用的交互行为。

核心 - 包括选择器,过渡,数据处理,本地化,颜色等。

地理 - 球面坐标,经纬度运算。

几何 - 提供绘制2D几何图形的实用工具。

布局 - 推导定位元素的辅助数据。

比例尺 - 数据编码和视觉编码之间转换。

可缩放矢量图形 - 提供用于创建可伸缩矢量图形的实用工具。

时间 - 解析或格式化时间,计算日历的时间间隔等。

二、添加元素

d3.select("body").append("p").text("小可爱!");

解析:

d3代表D3对象;

d3的select()方法通过使用CSS选择器的语法来选择DOM元素(如body),并且选择的是第一个匹配的元素,使用 selectAll() 可以返回所有匹配元素。

append()方法是在所选择元素内的末尾加上元素(如p),也即追加;

text()方法写入元素内容。

三、数据绑定

D3 一个很强大的特点是能将数据绑定到 DOM 上,也就是绑定到文档上。

例如网页中有段落元素 和一个整数 100,于是可以将整数 100 与 绑定到一起。绑定之后,当需要依靠这个数据才操作元素的时候,会很方便。

1. D3可以处理哪些类型的数据?

JS的数据类型。如数字,时间,字符串,布尔值,数组,对象等都可以。

D3自定义的数据类型。如集合(Set),映射(Map),嵌套(Nest),及各种颜色空间(RGB,HSL,L*a*b,HSV)对象等

最常用的是数组,JSON。特殊的有CSV,GeoJSON数据等。

2.如何绑定?

D3 中是通过以下两个函数来绑定数据的:

datum():绑定一个数据到选择集上

data():绑定一个数组到选择集上,数组的各项值分别与选择集的各元素绑定

1)datum()

在上面的代码中,用到了一个无名函数 function(d, i)。当选择集需要使用被绑定的数据时,常需要这么使用。其包含两个参数,其中:

d 代表数据,也就是与某元素绑定的数据。

i 代表索引,代表数据的索引号,从 0 开始。

datum只是替换一组新的数据。

2)data()


3.代码解析

selectAll("p")          //选择DOM中的所有段落。

data(dataset)        //计数和分析我们的数据值。

有五个值,之后我们的数据集执行了5次,每个值一次。

 enter()                 //绑定数据和DOM元素。

这个方法将数据传递到DOM中。如果数据值比相应的DOM元素多,就用enter()创建一个新元素的占位符。

append("p")                        //追加元素

通过enter()创建的占位符 在DOM中插入一个p元素。

text()              //为新创建的p标签插入一个文本值。


四、使用数据


五、绘制条形图

1)attr("class","bar")  //设置属性

2)d3.range(25) 生成25个数字:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24]。当然我们没有用它生成的数字,而只是用它来循环。真正生成数字的地方在map函数里。(数组)

3)d3.map()  //构建一个新的map

map函数,顾名思义映射,也就是生成一个对应该位置的一个数字(当然这里强大之处不仅仅是一个数字,还可以是对象)。(数组)

4)我们用d3.round函数对随机数保留一位小数四舍五入。(格式化)

5)我们用d3.random.normal(15,8)()生成一个满足期望是15,方差是8的正态分布的随机数。(数学)

六、使用D3绘制SVG

svg是可缩放矢量图语言,所以在svg上绘制的几何图形我们可以任意缩放,而不会导致像素模糊,当然也可以body上直接绘制空div,填充的方式,间接表现条形图,不过在通常来讲对前端人员来讲是不可能干的,所以我们一般在svg这个画布上绘制,先append一个div设置width,height,然后再添加rect,circle,svg上的几何图形有,rect,circle,还支持路径自由绘制。

1)创建svg

2)数据驱动的svg   select,data,enter,append

3)绘制圆:圆心坐标,直径

这里会使用D3经典的select-data-enter-append-attr/style的编程套路。

也就是选择元素-绑定数据-添加新元素的占位符-添加元素-设置属性或样式。

七、SVG绘制更自由的条形图

1)创建svg

2)绘制矩形,绑定数据

3)矩形条的属性和样式

绘制的思路是:

- 条宽

条宽 = 条实际宽度 + 间隙的宽度。

其中条宽 = (w / dataset.length)

间隙的宽度 = barPadding

- 条高

条高 = 条长-纵坐标(纵坐标是从上到下计算,即下方向为正) 即条高 = h - (d * 4)

- 条的颜色

条的颜色用据数据集生成的动态RGB值填充。

4)文本标记(可是数值)

x坐标:i * (w / dataset.length) + (w / dataset.length - barPadding) / 2

y坐标:h - (d * 4) + 14;

八、散点图绘制

1)创建svg

2)绘制圆,绑定数据

3)圆的属性和样式

九、线性比例尺

 1. 定义域和值域

比例尺有两个最重要的函数:

.domain([100, 500]) 定义域范围

.range([10, 350]) 值域范围

下面就是定义比例尺的方法:

var scale = d3.scale.linear()

            .domain([100, 500])

            .range([10, 350]);

比例尺最终都会对定义域执行相应的函数变换,然后再把这个中间数据线性变换到值域范围上。

2. 坐标轴的缩放

最大的X

d3.max(dataset, function(d) {    //返回 480

    return d[0];  //返回每个子数组的第一个元素

});

X轴缩放

var xScale = d3.scale.linear()

            .domain([0, d3.max(dataset, function(d) { return d[0]; })])

            .range([0, w]);

3.设定圆心的坐标

缩放后的坐标X值

.attr("cx",function(d) {

    return xScale(d[0]);

})

4.设定文本坐标值

.attr("x",function(d) {

    return xScale(d[0]);

})

注:点大小与圈大小成正比,想把大的放在下面,只要改变Y轴值域倒转即可: .range([h , 0]);

注:为了SVG边缘不被截断可以设置边距: .range([h - padding, padding]);

十、坐标轴

1.定义和创建x轴

//定义X轴

var xAxis = d3.svg.axis()

    .scale(xScale)

    .orient("bottom");

//创建X轴

svg.append("g").call(xAxis);

其中:

scale函数用来指定坐标轴的比例尺。

orient函数用来指定坐标轴的方位,可取值有left,right,top,bottom。

调用的时候任意的选择器call调用轴,或者xAxis(选择器)均可。

2. 调整X轴的样式

把坐标轴平移到下面:

svg.append("g")

.attr("class","axis")

.attr("transform","translate(0,"+ (h - padding) +")")

    .call(xAxis);

3. 设置刻度数

.ticks(5); //设置刻度数

注意这个ticks函数指定的数字只是一个大概的数量,具体生成多少D3会自动调整。

4.Y轴

十一、动画

var tran = d3.transition() - 创建一个过渡对象

tran.delay() - 设置延时时间,过渡经过一段时间后才会开始

tran.duration() - 设定过渡的持续时间

tran.ease() - 设定过渡的样式。

tran.attr() - 设置过渡属性

tran.style() - 设置过渡样式;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352