d3是一个及其庞大的库,有20个模块,大小也达到了216kb,是JQ1.x的2倍多,JQ3.x的3倍多,JQ本来就挺笨重的一个库,d3更是如此,但是它的功能确实很强悍~

d3的定位是一个科学计算库,并不是一个图形库,只是它能帮你算出路径,但是把路径画成svg图它是没有帮你的,有时候算出来的路径还要经过一系列处理。

所以说人生苦短,莫用d3~~当然,作为一个有追求的程序猿萌新,对这么一个优秀的库,我们还是秉承着了解学习的态度,下面由我带大家一起大概领略一下d3吧~


官网:https://d3js.org/

可以看到d3有如下这么20个模块,

 Arrays (Statistics, Search, Transformations, Histograms)(数组、 静态方法、查找类方法、变换类方法、直方图)
Axes(坐标轴)
Brushes(刷子)
Chords(弦图)
Collections(Object,Maps,Sets,Nests)(集合、对象、map、嵌套)
Colors(颜色)
Delimiter-Separated Values(d3-dsv)(dsv模块)
Dispatches(事件调度)
Dragging(拖拽)
Easings(过渡类型)
Forces(力学仿真模拟)
Number Formats(数值格式化)
Geographies(地理)
Hierarchies(层次结构布局)
Interpolators(插值器)
Paths(Canvas和SVG之间互转)
Polygons(二维多边形)
Quadtrees(四叉树)
Queues(队列)
Random Numbers(随机数)
Requests(数据请求)
Scales (Continuous, Sequential, Quantize, Ordinal)(比例尺)
Selections (Selecting, Modifying, Data, Events, Control, Local Variables, Namespaces)(选择集)
Shapes (Arcs, Pies, Lines, Areas, Curves, Symbols, Stacks)(形状)
Time Formats(日期时间)
Time Intervals(时间间隔)
Timers(定时器)
Transitions(过渡)
Voronoi Diagrams(Voronoi图)
Zooming(缩放)

因为d3在国内实在运用不广泛,只有特定的需求才需要用到它,就不详细解说每一个模块,挑几个实用一些的模块来说说吧~(说不定以后大家会遇到需要用到这方面功能的呢~)


在介绍模块前,不得不提的是d3的核心观念,accessor(访问器) genertor(生成器)

accessor(访问器)相当于先把传入的数组先做一次map映射,如d3.max(arr,accessor):

//例如想取得年纪最大的人
let arr = [{name:'david',age:12},{name:'james',age:14},{name:'rick',age:26},{name:'wade',age:18}];
let res = d3.max(arr,item=>item.age); //

generator(生成器),设置好生成器的需要的设置,然后这个生成器可以无限用,这样实现代码复用,提高性能,例如format:

let gen = d3.format('.3f');
gen(15); //15.000
gen(13.6798); //13.680

Array

有这些常用的方法max、min、extend(最大最小一起返回)、sum、mean(均值)、median(中位数)、quantile(分位数)

let arr = [5,8,12,26,18];
d3.extent(arr); //[5,26]

Collection

map方法,建立一个映射对象,item=>item.name是指定哪个是map的key

get,has,set分别是根据key来获取,查看是否存在,设定map对象,当然还有很多其他的方法

let arr1 = [{name:'david',age:12},{name:'james',age:14},{name:'james',age:17},{name:'rick',age:26},{name:'wade',age:18}];
let map = d3.map(arr1,item=>item.name);
console.log(map.get('james')) //{name: "james", age: 17}
console.log(map.has('james')) //true
map.set("alibaba", {name: "alibaba", age: 30});
console.log(map.get('alibaba')) //{name: "alibaba", age: 30}

color

d3.color('colorStr~~~'),把任意格式的字符串转化为一样的格式对象

console.log(d3.color('rgba(100,100,150,.5)'));//{r: 100, g: 100, b: 150, opacity: 0.5}
console.log(d3.color('rgb(200,129,150)'));//{r: 200, g: 129, b: 150, opacity: 1}
console.log(d3.color('gray'));//{r: 128, g: 128, b: 128, opacity: 1}
console.log(d3.color('#ccc'));//{r: 204, g: 204, b: 204, opacity: 1}

formats

number格式转换:

let gen = d3.format('.2f');
console.log(gen(15)); //15.00
console.log(gen(13.679)); //13.68
let gen2 = d3.format('5.0f');
console.log(gen2(1)); //

和c语言差不多,例如5.2f表示——总共5位,保留2位小数

还有其他,例如:

d3.format("$")(10);     //"$10"
d3.format("#")(0b1111); //"15"
d3.format(",")(100000); //"100,000"

date格式转换:

let dateGen = d3.timeFormat("%y年%m月%d日 %H:%M:%S");
console.log(dateGen(new Date())); //17年12月16日 10:16:26

相应的有逆转换:

let dateParse = d3.timeParse("%y年%m月%d日 %H:%M:%S");
console.log(dateParse('17年12月16日 10:16:28')); //Sat Dec 16 2017 10:16:28 GMT+0800 (中国标准时间)

shape

用于画任何图形,例如画饼图:

window.onload=function(){
//d3.pie生成对应数据
let data = [80,50,60,100,20];
let pieData = d3.pie()(data);
//d3.arc
let arc = d3.arc().innerRadius(0).outerRadius(150);
let g = d3.select('body').append('svg').attr('width',800).attr('height',600).append('g');
let color = ['#fc0','#cf0','#0fc','#f0c','#c0f'];
pieData.forEach((item,index)=>{
//arc(item)把每一份pie传给arc,生成路径
g.append('path').attr('d',arc(item)).attr('fill',color[index]).attr('stroke','#000');
})
g.attr('transform','translate(500,200) rotate(30)');
}

d3浅谈的更多相关文章

  1. [nRF51822] 14、浅谈蓝牙低功耗(BLE)的几种常见的应用场景及架构(科普类干货)

    蓝牙在短距离无线通信领域占据举足轻重的地位—— 从手机.平板.PC到车载设备, 到耳机.游戏手柄.音响.电视, 再到手环.电子秤.智能医疗器械(血糖仪.数字血压计.血气计.数字脉搏/心率监视器.数字体 ...

  2. 浅谈Linux下如何修改IP

    linux 下命令之浅谈//cd ..  //返回上一级//创建文件夹touch test.txt//Linux不区分大小写//往一个文件中追加内容echo "****" > ...

  3. 【微信小程序项目实践总结】30分钟从陌生到熟悉 web app 、native app、hybrid app比较 30分钟ES6从陌生到熟悉 【原创】浅谈内存泄露 HTML5 五子棋 - JS/Canvas 游戏 meta 详解,html5 meta 标签日常设置 C#中回滚TransactionScope的使用方法和原理

    [微信小程序项目实践总结]30分钟从陌生到熟悉 前言 我们之前对小程序做了基本学习: 1. 微信小程序开发07-列表页面怎么做 2. 微信小程序开发06-一个业务页面的完成 3. 微信小程序开发05- ...

  4. 浅谈蓝牙低功耗(BLE)的几种常见的应用场景及架构(转载)

    转载来至beautifulzzzz,网址http://www.cnblogs.com/zjutlitao/,推荐学习 蓝牙在短距离无线通信领域占据举足轻重的地位—— 从手机.平板.PC到车载设备, 到 ...

  5. 浅谈 Fragment 生命周期

    版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 源码:AndroidDemo/Fragment 文中如有纰漏,欢迎大家留言指出. Fragment 是在 Android 3.0 中 ...

  6. 浅谈 LayoutInflater

    浅谈 LayoutInflater 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 源码:AndroidDemo/View 文中如有纰漏,欢迎大家留言指出. 在 Android 的 ...

  7. 浅谈Java的throw与throws

    转载:http://blog.csdn.net/luoweifu/article/details/10721543 我进行了一些加工,不是本人原创但比原博主要更完善~ 浅谈Java异常 以前虽然知道一 ...

  8. 浅谈SQL注入风险 - 一个Login拿下Server

    前两天,带着学生们学习了简单的ASP.NET MVC,通过ADO.NET方式连接数据库,实现增删改查. 可能有一部分学生提前预习过,在我写登录SQL的时候,他们鄙视我说:“老师你这SQL有注入,随便都 ...

  9. 浅谈WebService的版本兼容性设计

    在现在大型的项目或者软件开发中,一般都会有很多种终端, PC端比如Winform.WebForm,移动端,比如各种Native客户端(iOS, Android, WP),Html5等,我们要满足以上所 ...

随机推荐

  1. python中获取执行脚本路径方法

    1.sys.path[0]:获取执行脚本目录绝对路径 #每次执行脚本时,python会将执行脚本目录加入PYTHONPATH环境变量中(sys.path获取) #!/usr/bin/python3 i ...

  2. POJ1094——拓扑排序和它的唯一性

    比较模板的topological-sort题,关键在于每个元素都严格存在唯一的大小关系,而一般的拓扑排序只给出一个可能解,这就需要每趟排序的过程中监视它是不是总坚持一条唯一的路径. 算法导论里面的拓扑 ...

  3. 高精度乘法--C++

    高精度乘法--C++ 模仿竖式乘法,在第一步计算的时候将进位保留,第一步计算完再处理进位.(见代码注释) 若要处理正负情况,可在数据输入后加以判断,处理比较简单. 小数计算也可参照该方法,不过对齐方式 ...

  4. SVN基础操作

    SVN基础操作 安装 #大多数Linux版本自带svn svn --version #如果没有安装可用yum安装 yum install subversion 生命周期 创建版本库 检出 更新 执行变 ...

  5. OpenCV调整彩色图像的饱和度和亮度

    问题 如何调整彩色图像的饱和度和亮度 解决思路 详细步骤: 将RGB图像值归一化到[0, 1] 然后使用函数cvtColor进行色彩空间的转换 接下来可以根据处理灰度图像对比度增强伽马变换或者线性变换 ...

  6. PAT甲题题解-1102. Invert a Binary Tree (25)-(建树,水题)

    就是把输入给的左孩子右孩子互换一下,然后输出层次遍历和中序遍历. #include <iostream> #include <algorithm> #include <c ...

  7. 《LINUX内核设计与实现》第一、二章学习总结

    第一章 Linux内核简介 (一)Unix是一个强大.健壮和稳定的操作系统,特点是: Unix很简洁,仅仅提供几个几百个系统调用并且有一个非常明确的设计目的 在Unix中,所有的东西都被当作文件对待, ...

  8. 每日Scrum(8)

    今天:在程序中嵌入剖面图,进行美化 明天:测试分析,找学弟学妹来体验我们的软件 任务看板: 燃尽图:

  9. Spring sprint @ first day

    前几天,我们讨论出任务划分.结合任务及个人情况,我认领校园网认证和网盘服务这块. 认证原理整3天,尝试编译2天,整合模块5天. 日期 时间 地点 工作 5.11 20:00 九实 下载mentohus ...

  10. level3

    伸冤下:老师的评论是有看到!看完我就去修改程序了,忘记回复请原谅!= = 前阵子都在修改功能和思路,但是由于一个细节的错误找不到,导致没有成品可以上传...求谅解. 细心真的很重要 = =!!! im ...