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:有帮你封装一下图形接口 ...
随机推荐
- 关于JRebel启动tomcat访问上次工程的index.jsp
检查了一下,原来我把上次配置文件包括JRebel配置文件一起复制过来,用JRebel启动时tomcat访问JRebel配置文件的目录下 这个是我上次文件的路径,把JRebel配置文件删除了,然后 di ...
- ubuntu16.04忘记密码解决方案
主要解决通过sudo apt-get install安装mysql时输入密码时输错导致安装成功后,无法登陆MySQL. 之前遇到这种问题时,我个人比较喜欢通过卸载并重新安装解决,后来觉得这个虽然可以解 ...
- shiro实战系列(六)之Authorization(授权)
授权,又称作为访问控制,是对资源的访问管理的过程.换句话说,控制谁有权限在应用程序中做什么. 授权检查的例子是:该用户是否被允许访问这个网页,编辑此数据,查看此按钮,或打印到这台打印机?这些都是 决定 ...
- debian文本配置网络备忘:/etc/network/interfaces
我装了wheezy有gnome3,xfce4: 郁闷的是,不论在gnome还是xfce4中 我都无法图形登录或者切换用户到root: 而且我无法在普通用户下图形修改网络配置: 我也搜索不到启用root ...
- lnmp服务器配置HTTPS
server { server_name ktsf.weiyou18.com; #listen 80; listen 443; ssl on; ssl_certificate /usr/local/n ...
- Java UDP和TCP的区别
为什么要写这篇博客:是这样的,最近听朋友说,有不少公司面试的时候会问道TCP和UDp的却别,所以就写出一篇简单的来描述他们之间的区别,送给那些即将面试的朋友们. UDP: 1.UDP, a.将数据以及 ...
- redis的使用,相比memcached
redis支持数据持久化,不像memcached断电或者重启就丢失数据了. 支持持久化主要有两种方式,在redis.conf配置文件里配置. 1. 使用.rdb格式存储,配置save参数(save N ...
- bat 传递超过10个参数(bat参数遍历)
批处理文件中可引用的参数为%0~%9, %0是指批处理文件的本身,也可以说是一个外部命令:%1~%9是批处理参数,也称形参:而替换形参的实参若超过了批处理文件中所规定数值(9个)且想在批处理文件中应用 ...
- React Native创建一个APP
React Native 结合了 Web 应用和 Native 应用的优势,可以使用 JavaScript 来开发 iOS 和 Android 原生应用.在 JavaScript 中用 React 抽 ...
- Spring Data JPA、MyBatis还有Hibernate有什么区别
原文:https://www.imooc.com/article/19754?block_id=tuijian_wz Spring Data JPA.MyBatis还有Hibernate有什么区别 2 ...