D3.js

时间:2022-12-16 21:36:06

html代码:

<div id="id">
<p>Apple</p>
<p id="aa">Pear</p>
<p>Banana</p>
</div>
<div>
<p>a</p>
<p>b</p>
<p>c</p>
</div>

页面效果:

D3.js

1.选择元素和绑定数据

- 选择元素

(1) select(): 选择所有指定元素的第一个

var div = d3.select('#id');
var p = div.select("p");
p.style("color","red")

页面效果:

D3.js

(2) selectAll():选择所有指定元素的全部

var div = d3.select('div');
var p = div.selectAll("p");
p.style("color","red")

页面效果:

D3.js

- 绑定数据

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

var str = "China";
var arr = ['a','b','c']
var body = d3.select("body");
var p = body.selectAll("p");
p.datum(str);
p.text(function(d,i){
return "第" + i + "个元素绑定的数据是" + d;
})

页面效果:

D3.js

  上面的代码中,用到了一个无名函数function(d,i){},其中:

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

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

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

var dataset = ["I like dog","I like cat","I like snake"];
var body = d3.select("body");
var p = body.selectAll("p");
p.data(dataset).text(function(d,i){
return d;
})

页面效果:

D3.js

2. 插入元素

(1) append():在选择集末尾插入元素

var div = d3.select('#id');
div.append("p").text("append p element");

页面效果:

D3.js

(2) insert():在选择集前面插入元素

var div = d3.select('#id');
div.insert("p","#aa").text("insert p element");

页面效果:

D3.js

3. 删除元素

remove():删除一个元素

var div = d3.select("#id");
var p = div.select("p")
p.remove();

页面效果:

D3.js

4. 一个简单的图表

var width = 300;   // 画布的宽度
var height = 300; // 画布的高度 var svg = d3.select("body") // 选择文档中的body元素
.append("svg") // 添加一个svg元素
.attr("width",width) // 设定宽度
.attr("height",height) // 设定高度 var dataset = [250, 210, 170, 130, 90] // 数据(表示矩形的宽度) var rectHeight = 25; // 每个矩形所占的像素高度(包括空白) //----------------------------------------------------------
svg.selectAll("rect") // 选择svg内所有的矩形
.data(dataset) // 绑定数组
.enter() // 指定选择集的enter部分
.append("rect") // 添加足够数量的矩形元素
//----------------------------------------------------------
// 这段代码要牢记,当有数据,而没有足够图形元素的时候,使用此方法可以添加足够的元素 .attr("x",20)
.attr("y",function(d,i){
return i * rectHeight;
})
.attr("width",function(d,i){
return d;
})
.attr("height",rectHeight-2) .attr("fill","#ccc"); // 设置颜色

页面效果:

D3.js

5. 比例尺:将某一区域的值映射到另一区域,其大小关系不变

- 线性比例尺

// 要求:将dataset中最小的值映射成0,最大的值映射成300
var dataset = [1.2, 2.3, 0.9, 1.5, 3.3]; var min = d3.min(dataset);
var max = d3.max(dataset); var linear = d3.scale.linear().domain([min,max]).range([0,300]); console.log(linear(0.9)); // 返回0
console.log(linear(2.3)); // 返回175
console.log(linear(3.3)); // 返回300

D3.js

  d3.scale.linear() 返回一个线性比例尺。domain() 和 range() 分别设定比例尺的定义域和值域。d3.min()和d3.max()两个函数经常与比例尺一起出现。值得注意的是,d3.scale.linear() 的返回值,是可以当做函数来使用的。因此,才有这样的用法:linear(0.9)。

- 序数比例尺: 定义域和值域一一对应关系

var index = [0, 1, 2, 3, 4];
var color = ["red", "blur", "green", "yellow", "black"]; var ordinal = d3.scale.ordinal().domain(index).range(color); console.log(ordinal(0)); // 返回red
console.log(ordinal(2)); // 返回green
console.log(ordinal(4)); // 返回black

D3.js

- 给柱形图添加比例尺

var width = 500;   // 画布的宽度
var height = 500; // 画布的高度 var svg = d3.select("body") // 选择文档中的body元素
.append("svg") // 添加一个svg元素
.attr("width",width) // 设定宽度
.attr("height",height) // 设定高度 var dataset = [2.5, 2.1, 1.7, 1.3, 0.9]; var linear = d3.scale.linear().domain([0, d3.max(dataset)]).range([0, 200]) var rectHeight = 25; svg.selectAll("rect")
.data(dataset)
.enter()
.append("rect")
.attr("x",20)
.attr("y",function(d, i){
return i * rectHeight;
})
.attr("width",function(d){
return linear(d) // 这里添加比例尺
})
.attr("height",rectHeight-2)
.attr("fill","#ccc")

D3.js

修改值域 .range([0, 400]) 后:

D3.js

柱形图改变。

D3.js的更多相关文章

  1. D3&period;js学习(七)

    上一节中我们学会了如何旋转x轴标签以及自定义标签内容,在这一节中,我们将接触动画(transition) 首先,我们要在页面上添加一个按钮,当我们点击这个按钮时,调用我们的动画.所以,我们还需要在原来 ...

  2. D3&period;js学习(一)

    从今天开始我将和大家一起学习D3.js(Data-Driven Documents),由于国内关于D3的学习资料少之又少,所以我觉得很有必要把自己学习过程记录下来,供同学们参考,如果文章有有哪些表达有 ...

  3. D3&period;js学习记录

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. D3&period;js部署node环境开发

    总结一段D3.js部署node环境的安装过程 准备阶段: 首先电脑上要安装node环境,这个阶段过滤掉,如果node环境都不会装,那就别玩基于node环境搞的其他东西了. 搭建环境: 我在自己的F:系 ...

  5. d3&period;js读书笔记-1

    d3.js入门 d3入门 D3是一个强大的数据可视化工具,它是基于Javascript库的,用于创建数据可视化图形.在生成可视化图形的过程中,需要以下几步: 把数据加载到浏览器的内存空间: 把数据绑定 ...

  6. 【 D3&period;js 进阶系列 — 6&period;1 】 缩放的应用(Zoom)

    缩放(Zoom)是另一种重要的可视化操作,主要是使用鼠标的滚轮进行. 1. zoom 的定义 缩放是由 d3.behavior.zoom() 定义的. var zoom = d3.behavior.z ...

  7. &lbrack;资料搜集狂&rsqb;D3&period;js数据可视化开发库

    偶然看到一个强大的D3.js,存档之. D3.js 是近年来十分流行的一个数据可视化开发库. 采用BSD协议 源码:https://github.com/mbostock/d3 官网:http://d ...

  8. D3&period;js 用层画条形图

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  9. 【 D3&period;js 入门系列 --- 3 】 做一个简单的图表!

    前面说了几节,都是对文字进行处理,这一节中将用 D3.js 做一个简单的柱形图. 做柱形图有很多种方法,比如用 HTML 的 div 标签,或用 svg . 推荐用 SVG 来做各种图形.SVG 意为 ...

  10. 【 D3&period;js 入门系列 --- 2&period;1 】 关于如何选择,插入,删除元素

    在D3.js中,选择元素的函数有两个:select 和 selectAll . 先说明一下它们的区别: select 是选择所有指定元素的第一个 selectAll 是选择指定元素的全部(以用于后面同 ...

随机推荐

  1. SQL语句中的where 1&equals;1 和0&equals;1

    摘自:http://blog.sina.com.cn/s/blog_afe616ab0101camd.html SQL where 1=1 和0=1的作用 where 1=1; 这个条件始终为True ...

  2. 说说ASP&period;NET的表单验证

    FormsAuthentication是ASP.NET运行时提供的一种Web身份验证方案,以cookie为信息载体,同其它身份验证方案相比,此方案广泛应用于各类的Web应用中,其实现原理其实和具体的W ...

  3. Oracle-07:别名,去重,子查询

    ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 依旧提供数据库脚本供操作 create table DEPT ( deptno ) not null, dna ...

  4. 基于 HTTP 请求拦截,快速解决跨域和代理 Mock

    近几年,随着 Web 开发逐渐成熟,前后端分离的架构设计越来越被众多开发者认可,使得前端和后端可以专注各自的职能,降低沟通成本,提高开发效率. 在前后端分离的开发模式下,前端和后端工程师得以并行工作. ...

  5. &lbrack;NIO-4&rsqb;选择器

    选择器 最后,我们探索一下选择器.由于选择器内容比较多,所以本篇先偏理论地讲一下,后一篇讲代码,文章也没有什么概括.总结的,写到哪儿算哪儿了,只求能将选择器写明白,并且将一些相对重要的内容加粗标红. ...

  6. grafana worldPing插件

    worldPing插件安装 官网介绍:https://grafana.com/plugins/raintank-worldping-app/installation 插件下砸地址:https://gr ...

  7. java 使用jsoup处理html字符

    依赖的jar <dependency> <groupId>org.jsoup</groupId> <artifactId>jsoup</artif ...

  8. python性能监控初试

    标 题: python性能监控初试作 者: itdef链 接: http://www.cnblogs.com/itdef/p/3990765.html 欢迎转帖 请保持文本完整并注明出处 之前性能统计 ...

  9. 来自Redis 作者的看法 —— Twemproxy

    虽然大量用户使用Redis节点的大型农场,但从项目本身来看,Redis主要是单实例业务. 我有很大的计划与项目一起分发,在某种程度上我不再评估Redis的任何线程版本:对我来说,从Redis的角度看, ...

  10. Jenkins2&period;138配置slave节点时,启动方法只有两个选项

    Jenkins2.138配置slave节点时,启动方法只有两个选项,并没有通过javaweb代理启动这个选项 解决办法 全局安全配置->代理->选择随机选取