d3浅谈

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

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

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



官网:https://d3js.org/

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

 1 Arrays (Statistics, Search, Transformations, Histograms)(数组、 静态方法、查找类方法、变换类方法、直方图)
 2 Axes(坐标轴)
 3 Brushes(刷子)
 4 Chords(弦图)
 5 Collections(Object,Maps,Sets,Nests)(集合、对象、map、嵌套)
 6 Colors(颜色)
 7 Delimiter-Separated Values(d3-dsv)(dsv模块)
 8 Dispatches(事件调度)
 9 Dragging(拖拽)
10 Easings(过渡类型)
11 Forces(力学仿真模拟)
12 Number Formats(数值格式化)
13 Geographies(地理)
14 Hierarchies(层次结构布局)
15 Interpolators(插值器)
16 Paths(Canvas和SVG之间互转)
17 Polygons(二维多边形)
18 Quadtrees(四叉树)
19 Queues(队列)
20 Random Numbers(随机数)
21 Requests(数据请求)
22 Scales (Continuous, Sequential, Quantize, Ordinal)(比例尺)
23 Selections (Selecting, Modifying, Data, Events, Control, Local Variables, Namespaces)(选择集)
24 Shapes (Arcs, Pies, Lines, Areas, Curves, Symbols, Stacks)(形状)
25 Time Formats(日期时间)
26 Time Intervals(时间间隔)
27 Timers(定时器)
28 Transitions(过渡)
29 Voronoi Diagrams(Voronoi图)
30 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); //26

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));   //    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)‘);
}
时间: 2024-10-16 01:04:32

d3浅谈的相关文章

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

蓝牙在短距离无线通信领域占据举足轻重的地位—— 从手机.平板.PC到车载设备, 到耳机.游戏手柄.音响.电视, 再到手环.电子秤.智能医疗器械(血糖仪.数字血压计.血气计.数字脉搏/心率监视器.数字体温计.耳温枪.皮肤水分计等), 再到智能家居等领域均占有一席之地. 而蓝牙低功耗(BLE)是在蓝牙4.0协议上修改以适用低功耗应用场景的一种蓝牙协议. 随着上一股智能消费类电子大潮的到来,BLE的各种应用也像雨后春笋般在市场上铺开. 如果想 紧跟蓝牙协议的最新动态 ,可以在https://www.b

浅谈MySQL索引背后的数据结构及算法

摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持 也各不相同,因此MySQL数据库支持多种索引类型,如BTree索引,哈希索引,全文索引等等.为了避免混乱,本文将只关注于BTree索引,因为这是 平常使用MySQL时主要打交道的索引,至于哈希索引和全文索引本文暂不讨论. 文章主要内容分为四个部分. 第一部分主要从数据结构及算法理论层面讨论MySQL数据库索引的数理基础. 第二部分结合MySQL数据库中

浅谈深度学习中潜藏的稀疏表达

浅谈深度学习中潜藏的稀疏表达 “王杨卢骆当时体,轻薄为文哂未休. 尔曹身与名俱灭,不废江河万古流.” — 唐 杜甫<戏为六绝句>(其二) [不要为我为啥放这首在开头,千人千面千理解吧] 深度学习:概述和一孔之见 深度学习(DL),或说深度神经网络(DNN), 作为传统机器学习中神经网络(NN).感知机(perceptron)模型的扩展延伸,正掀起铺天盖地的热潮.DNN火箭般的研究速度,在短短数年内带来了能“读懂”照片内容的图像识别系统,能和人对话到毫无PS痕迹的语音助手,能击败围棋世界冠军.引

浅谈 Data URI 与 BASE 64 编码

前言(废话):鼓捣 Stylish 的时候发现了这么个奇怪的代码行: Data:image/gif;BASE64,R0lGODlhEAAQAKEAAEKF9NPi/AAAAAAAACH5BAEAAAIALAAAAAAQABAAAAIkFI6Zpu0YYnxnAvtC0hTzzH3UJY6kSUqdiCltu7GjBKMKgwoFADs= 由于自己有点 HTML/CSS 基础,看得出来这是在引用图片,可是后面这么长一串乱码难道就是图片地址吗?经过漫长的查询(突破点是 BASE64,我记得这是种加密

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

转载来至beautifulzzzz,网址http://www.cnblogs.com/zjutlitao/,推荐学习 蓝牙在短距离无线通信领域占据举足轻重的地位—— 从手机.平板.PC到车载设备, 到耳机.游戏手柄.音响.电视, 再到手环.电子秤.智能医疗器械(血糖仪.数字血压计.血气计.数字脉搏/心率监视器.数字体温计.耳温枪.皮肤水分计等), 再到智能家居等领域均占有一席之地. 而蓝牙低功耗(BLE)是在蓝牙4.0协议上修改以适用低功耗应用场景的一种蓝牙协议. 随着上一股智能消费类电子大潮的

.net中对象序列化技术浅谈

.net中对象序列化技术浅谈 2009-03-11 阅读2756评论2 序列化是将对象状态转换为可保持或传输的格式的过程.与序列化相对的是反序列化,它将流转换为对象.这两个过程结合起来,可以轻松地存储和传输数 据.例如,可以序列化一个对象,然后使用 HTTP 通过 Internet 在客户端和服务器之间传输该对象.反之,反序列化根据流重新构造对象.此外还可以将对象序列化后保存到本地,再次运行的时候可以从本地文件 中“恢复”对象到序列化之前的状态.在.net中有提供了几种序列化的方式:二进制序列化

浅谈——页面静态化

现在互联网发展越来越迅速,对网站的性能要求越来越高,也就是如何应对高并发量.像12306需要应付上亿人同时来抢票,淘宝双十一--所以,如何提高网站的性能,是做网站都需要考虑的. 首先网站性能优化的方面有很多:1,使用缓存,最传统的一级二级缓存:2,将服务和数据库分开,使用不同的服务器,分工更加明确,效率更加高:3,分布式,提供多台服务器,利用反向代理服务器nginx进行反向代理,将请求分散开来:4,数据库的读写分离,不同的数据库,将读操作和写操作分开,并实时同步即可:5,分布式缓存,使用memc

单页应用SEO浅谈

单页应用SEO浅谈 前言 单页应用(Single Page Application)越来越受web开发者欢迎,单页应用的体验可以模拟原生应用,一次开发,多端兼容.单页应用并不是一个全新发明的技术,而是随着互联网的发展,满足用户体验的一种综合技术. SEO 一直以来,搜索引擎优化(SEO)是开发者容易忽略的部分.SEO是针对搜索(Google.百度.雅虎搜索等)在技术细节上的优化,例如语义.搜索关键词与内容相关性.收录量.搜索排名等.SEO也是同行.市场竞争常用的的营销手段.Google.百度的搜

浅谈html标签

浅谈html各常用标签用法 标题标签:<h1>-<h6>来表示,使标题字体变粗. <br />换行标记 <hr />水平分隔符 &nbsp空格符 &copy版权符 <a href>a标签超链接 href可接链接地址 <p>段落标签<blockquote>引用标签及可用做缩进 <table>表格中的<ul>无序列表<ol>有序列表<dl>自定义列表<row