d3 选择器
一、隔了一段时间没看D3了,好多api又陌生了。武林太大,唯有自强不息。
D3 选择器算是学习D3的第一步吧。 跟 学习JQ一样。先熟悉下api,才能够如鱼得水,手到勤来。
二、 选择器
1.选择器
/*
1.d3.select(dom); dom => 可以是类,ID。说白了跟JQ的 $(dom) 完全一样。不过select返回的时候。页面中匹配到的第一个元素。 或者为null 2.d3.selectAll(dom); => 跟JQ完全一样。 $(dom) */
2.内容(主要是更改DOM元素的属性和类名的方法)
/*
1. selection.attr(name[, value])
意思是
(1) d3.selectAll('p').attr('data-href','http://baidu.com');
相当于JQ中的 $(dom).attr(); 的方法一样。
(2) 其中value 为function的时候 (d,i, this) i=> 的选中元素的序号, this 当前的元素
d3.select(this).attr('data-href',i)
d3.selectAll('p').attr('data-href',function(d,i){
return i;
}) 2.section.classed(name[,value]);
跟上面的attr 基本一样。顾名思义 => 就是对类名的操作。
eg: d3.selectAll('div').classed({"foo":true,"bar":"false"});
或者
d3.selectAll('div').classed('foo bar',true);
true => 对匹配的元素还为添加这个class名的元素添加这个class名字。
false => 对匹配的元素有这个class名的元素去掉这个class名字
3.section.style(name[, value[, priority]])
跟上面classed 的用法基本一样。我就不细说了
eg:
d3.selectAll('span').style({'color':'red','font-size':'50px'});
4.selection.property(name[, value])
跟classed的方法差不多。
主要是针对表单元素中 的属性 比如 : disable,checkbox,radio。readonly等等 eg : de.selectAll('input').property({'checkbox':true,'disable':false})
5.select.text();
这个方法跟JQ的text(); 方法一样。
6.section.html(); 同上
7.section.append(); 想选中元素的后面插入dom节点
跟jq一样
8. section.insert(); 选中的dom 元素中的子节点前面插入
9.section.remove(); 溢出 */
3.section.data()
/*
section.data([values[, key]);的方法比较复杂。 主要涉及到几点
1.一种情况就是选中的元素和data数据刚好匹配。 这时候
可以直接
html:
<div class="div"></div>
<div class="div"></div> d3.select("body").selectAll('.div').data([1,23]).text(function(d){
return d;
});
2. 匹配元素有0个。单时候数据有多条的时候。
d3.selectAll('.a').data([1,2,3]).enter().append('.a').text(function(d){
return d;
});
3. 匹配的元素有多个的时候。也就是数据更少。需要把多余的元素删掉
d3.selectAll('.b').data([1]).exit().remove(); 所以我们写方法的时候。基本都是
d3.selectAll('.c').data([1,2,3]).enter().append('.a').exit().remove();
你们肯定发现了。这跟JQ的链式编程一样。 */
//1.
var matrix = [
[11975, 5871, 8916, 2868],
[ 1951, 10048, 2060, 6171],
[ 8010, 16145, 8090, 8045],
[ 1013, 990, 940, 6907]
]; var tr = d3.select("body").append("table").selectAll("tr")
.data(matrix)
.enter().append("tr"); var td = tr.selectAll("td")
.data(function(d) { return d; })
.enter().append("td")
.text(function(d) { return d; }); /*
section.enter();
section.exit();
section.remove();的方法就不介绍了。上面有啊 */
/*
d3.section.datum 获取或设置每个选定的元素绑定的数据。不像selection.data方法,这种方法不计算一个连接(并因此不计算enter和exit的选择)。此方法在selection.property之上实现: d3.selection.prototype.datum = function(value) {
return arguments.length < 1
? this.property("__data__")
: this.property("__data__", value);
};
*/
d3 选择器的更多相关文章
- D3.js使用过程中的常见问题(D3版本D3V4)
目录 一.学习D3我必须要学习好SVG矢量图码? 二.如何理解D3给Dom节点绑定数据时的Update.Enter和Exit模式 三.D3绑定数据时用datum与data有什么不一样? 四.SVG图中 ...
- d3 + geojson in node
d3.js本来主要是用于用“数据驱动dom”,在浏览器端,接收后端数据,数据绑定,渲染出svg. 即使是在ng中用,也是会由框架打包,供客户端下载. 那么,如果用所谓后端渲染,发布静态的svg,那就要 ...
- 1216 Vue基础
目录 前端框架 Vue 1.简介 1.1 优点 2 使用 2.1 基础 2.2 文本指令 2.3 事件指令 2.4 属性指令 JS面向对象补充 前端框架 angular ---更新程度太快,且不向下兼 ...
- d3.js制作条形时间范围选择器
此文章为原创文章,原文地址:https://www.cnblogs.com/eagle1098/p/12146688.html 效果如上图所示. 本项目使用主要d3.js v4制作,可以用来选择两年的 ...
- D3的基本设计思路
学习一项新技术,首先要搞清楚它的基本设计思路,有了这个宏观的技术架构,使用该技术起来,就会得心应手了.否则,就会不知道如何下手,即使看到人家的例子程序,可能也不知其所以然. 下面,就简单的结合自己研究 ...
- 精通D3.js学习笔记(1)基础的函数
买了本吕大师的d3可视化.最近来学习一下,做个笔记. 1.选择元素 select(第一元素) 和selectAll(全部的元素) 类似css的选择器.也可以是dom选中的. var i ...
- D3.js 其他选择元素方法
在上一节中,已经讲解了 select 和 selectAll,以及选择集的概念.本节具体讲解这两个函数的用法. 假设在 body 中有三个段落元素: <p>Apple</p> ...
- D3序
最近做公司的APM项目涉及到数据可视化,简单调研了一下目前业内推崇的工具,自然最终选择是非D3莫属,特别是看了官网上那些绝妙的示例之后,感觉这玩意儿炫到爆!选择D3最重要的一点是D3提供基础的必要的功 ...
- d3可视化实战02:理解d3数据驱动的真正含义
前文中已经提到,SVG从诞生之初起就可以非常方便地使用javascript脚本语言来进行其DOM对象的控制.当然,控制的方法有很多,有直接控制SVG对象的方法,例如使用原生js:有帮你封装一下图形接口 ...
随机推荐
- 【转】PHP----JS相互调用
JS调用PHP 1.取值: 执行html,得到一个弹窗,提示:I from PHP <script type="text/javascript" src="http ...
- 如何将tensor的内容输出到文本文件
local part2 = self.convModel:forward({linputs, rinputs}) ) local file = io.open('/home/xbwang/Deskto ...
- sublime出现 unable download.......
I managed to fix this by changing my package settings. I made my osx downloader preference curl, and ...
- OpenCV 中轮廓包裹的几个函数boundingRect、minAreaRect、minEnclosingCircle用法
当我们得到对象轮廓后,可用boundingRect()得到包覆此轮廓的最小正矩形,minAreaRect()得到包覆轮廓的最小斜矩形,minEnclosingCircle()得到包覆此轮廓的最小圆形, ...
- css心跳动画
1.图片无限放大缩小,类似心跳 css如下 @keyframes scaleDraw { /*定义关键帧.scaleDrew关键帧名称*/ 0%{ transform: scale(1); /*开始为 ...
- 《MySQL:菜鸟入门系列》
关于数据库相关知识,几乎是互联网从业者逃不开的一个必备技能,特别是对于DB.开发和测试童鞋来说,更显得重要... 关于MySQL,推荐如下几本书: 入门级:<MySQL必知必会> 进阶级: ...
- day 26
今日内容 classmethod 让这个类中的方法绑定自己类,这样就可以直接用类调用该方法. staticmethod 让类中的方法编程非绑定方法,也就是是这个类中的方法编程普通函数. ####### ...
- git和github使用教程
看官请移步git和github简单教程, 本文是上述链接的截图,担心哪天作者不小心删除了,备一份在自己这里,仅为自己看着方便.侵权请告知
- 从字节码层面,解析 Java 布尔型的实现原理
最近在系统回顾学习 Java 虚拟机方面的知识,其中想到一个很有意思的问题:布尔型在虚拟机中到底是什么类型? 要想解答这个问题,我们看 JDK 的源码是无法解决源码的,我们必须深入到 class 文件 ...
- DelayQueue 订单限时支付实例
1.订单实体 package com.zy.entity; import java.util.Date; import java.util.concurrent.Delayed; import jav ...