D3.js基础

一、D3基础

1. D3是什么

D3(Data-Driver Documents,数据驱动文档)是基于数据来操作文档的JS库。主要用来做数据可视化的,能帮助用户使用HTML、CSS、SVG、Canvas来展示数据。D3遵循现有的Web标准无需其他任何框架而独立在现代浏览器中,它结合强大的可视化组件来驱动DOM操作。

D3可将数据绑定到DOM上,然后根据数据来计算对应DOM的属性值。D3不是一个框架,因此没有操作上的限制。

2. D3安装

D3是一个开源项目,作者是纽约时报的工程师。D3项目的代码托管于Github中。

使用npm安装
npm install d3

D3可运行在Node和Webworkers中,在Node环境中使用DOM时必须提供自己的DOM实现。推荐使用JSDOM,为避免全局document建议将DOM传递给d3.select或将NodeList传递给d3.selectAll。

var d3 = require('d3');
var jsdom = require('jsdom');

var dom = jsdom.jsdom();
d3.select(dom.body).append(''svg);

在本地开发环境中,由于浏览器的安全策略,不能直接读取本地文件。因此必须运行在一个服务器环境,推荐使用NodeJS的http-server。服务启动后当前目录中将启动一个 http://localhost:8080 的服务。

# 安装HTTP服务器
npm install -g http-server

# 后台运行HTTP Server
http-server &

二、Arrays

数组是一种常用的数据结构,JS支持原声数组操作。

JS数组自身操作

  • array.pop 移除最后一个元素
  • array.push 追加一个或多个元素
  • array.reverse 数组翻转
  • array.shift 移除首个元素
  • array.sort 数组排序
  • array.splice 数组添加移除元素
  • array.unshift 在数组首位前添加元素

JS数组存取操作

  • array.concat 数组合并
  • array.join 数组元素连接
  • array.slice 提取切片
  • array.indexOf 查找特定元素的索引
  • array.lastIndexOf 查找指定元素最后一个索引

JS数组迭代操作

  • array.filter 数组过滤
  • array.forEach 对元素执行方法
  • array.every 是否每个元素都符合给定条件
  • array.map 根据指定操作对每个元素执行后返回一个新数组
  • array.some 是否存在符合某个条件的元素
  • array.reduce 从左到右执行reduce操作并返回一个值
  • array.reduceRight 从右向左执行reduce操作并返回一个值

D3数组操作

统计类方法(Statics)

最小值 d3.min(array[, accessor])<>

返回给定数组中的最小值,若数组为空则返回undefined。若指定accessor,则相当于在计算最小值之前调用 array.map(accessor)。与内置 Math.min 不同,d3.min忽略 undeifned, null, NaN等值。在忽略缺失数据时有用。此外,元素使用自然排序而非数值排序。

最大值 d3.max(array[, accessor])<>

返回给定数组中的最大值,若数组为空则返回 undefined。若指定accesssor则相当于在计算最小值之前调用 array.map(accessor)。

与内置Math.max不同的是,d3.min忽略undefined、null、NaN,在忽略缺失数据时有用。此外,元素使用自然排序而非数值排序。

最小值和最大值 d3.extent(array[, accessor])<>

根据指定数组返回最小值和最大值,若数组为空则返回 [undefined, undefined]。若指定accessor则相当于计算极值之前调用 array.map(accessor)。

求和 d3.sum(array[, accessor])<>

根据指定的数组计算和值,若数组为空则返回0.若指定了accessor则相当于在求和之前调用array.map(accessor),此方法会忽略undefined和NaN。

均值 d3.mean(array[, accessor])<>

根据指定的数组返回数组的均值。若数组为空则返回undefined, 若指定accessor则相当于在计算之前调用 array.map(accessor) ,此方法会忽略 undefined 和 NaN。

中位数 d3.median(array[, accessor])<>

根据指定数组使用R-7方法返回数组中位数。若数组为空则返回 undefined。若指定 accessor 则相当于在计算之前调用 array.map(accessor)。此方法会忽略 undefined 和 NaN。

分位数 d3.quantile(array, p[, accessor])<>

根据指定的数组返回 p-分位数,p是[0,1]之间的小数。例如中位数相当于 p=0.5,使用 p=0.25 计算第一个四分位数, p=0.75 表示第三个四分位数。

var arr = [0,10,30];
d3.quantile(arr, 0); //0
d3.quantile(arr, 0.5);//10
d3.quantile(arr, 1);//30

d3.quantile(arr, 0.25);//5
d3.quantile(arr, 0.75);//20
d3.quantile(arr, 0.1);//2

方差 d3.variance(array[, accessor])<>

返回指定数组的总体方差的无偏估计(unbiased estimator of the population variance),若数组中包含的元素小于2则返回undefinded。若指定accessor则相当于在计算之前调用了 array.map(accessor),此方法忽略了 undefined 和 NaN。

标准差 d3.deviation(array[, accessor])<>

返回数组的标准差,若数组中包含的元素个数小于2则返回 undefined。若指定 accessor 则相当于在计算之前调用了 array.map(accessor) ,此方法忽略了 undefined 和 NaN。

查找类方法(Search)

扫描 d3.scan(array[, comparator])<>

对指定数组进行线性扫描,根据指定的比较操作返回最终元素的索引。若给定的数组不包含可比较的元素(比如比较操作返回NaN)则返回undefined,若无指定比较操作则默认 ascending。

var arr = [{foo:42}, {foo:91}];

d3.scan(arr, function(a,b){
  return a.foo - b.foo;
}); //0

d3.scan(arr, function(a,b){
  return b.foo - a.foo;
});//1

此方法与min类似,scan使用比较操作而非访问器,返回的是索引而非值。

d3.bisectLeft(array, x[, lo[, hi]])

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

推荐阅读更多精彩内容