d3.js:数据可视化利器之 交互行为:响应DOM事件
selection.on:事件监听操作符
on()操作符可以添加或移除选择集中每个 DOM元素的事件监听函数:
- selection.on(type[,listener[,capture]])
参数type是一个DOM事件类型字符串,指明要监听的事件,如: "click"、 "mouseover"、 "submit"等,可以使用浏览器支持的任何事件类型。
参数capture是可选的,对应于W3C的useCapture标志。
获取/移除当前监听函数
参数listener是可选的,如果未指定该参数,则on()调用返回 type类型的当前监听函数。
要移除一个事件监听,将listener参数置为null即可。
为事件注册监听函数
参数listener是一个监听函数,当d3捕捉到DOM事件后,将调用该监听函数, 并忽略该函数的返回值。监听函数也是一个访问器,d3触发监听函数时, 将this指向当前的DOM对象,并以参数形式传入其对应的数据和在选择集中的序号。
注册多个监听函数
如果在同一个DOM对象上已经注册有type类型的监听函数,那么再次调用on() 进行注册将移除之前注册的监听函数。如果需要对一种事件注册多个监听函数,可以在 事件类型名称后增加一个可选的命名空间,比如:"click.foo"、"click.bar"。
d3.event:DOM事件对象
你可能已经注意到,d3的事件监听函数在触发时,传入的参数中没有DOM事件对象。 这样设计的出发点是让监听函数可以和其他访问器函数一样,能够获得DOM对象对应 的数据和序号。
但是,在很多应用场景下,我们还是需要DOM事件对象,比如:
- 当鼠标点击时,我们需要它的xy坐标,或者判断用户点击的是左键还是右键;
- 或者,当用户敲击键盘时,我们需要
- 或者,我们需要调用DOM事件对象的preventDefault()来禁止浏览器对某个事件的默认行为;
- 或者,我们需要调用stopPropagation()来阻止事件的冒泡行为......
d3使用一个全局变量来提供DOM事件对象:d3.event。
d3.event仅在监听函数中有效。每当事件触发时,d3就将DOM事件对象赋给d3.event, 并在监听器处理完之后将其清理。
d3.event就是你熟悉的Event对象,所以,随便用。
d3.mouse:获得鼠标事件位置
尽管可以使用DOM事件对象的pageX和pageY获得鼠标位置,d3提供了更好用的方法:
- d3.mouse(container)
参数container表示一个HTML元素,d3.mouse()将返回鼠标位置相对于 这个容器元素的x、y坐标。
这意味着对同一个鼠标事件,我们只要传入不同的容器元素,就可以获得鼠标位置 不同的相对位置!
解脱了很多令人烦躁的计算过程,对吧?
参考资料:http://***/course/54fd40cfe564e50d50dcf284/
d3.js:数据可视化利器之 交互行为:响应DOM事件的更多相关文章
- d3.js:数据可视化利器之快速入门
hello,data! 在进入d3.js之前,我们先用一个小例子回顾一下将数据可视化的基本流程. 任务 用横向柱状图来直观显示以下数据: var data = [10,15,23,78,57,29,3 ...
- d3.js:数据可视化利器之 修改文档:DOM操作符
style: CSS样式操作符 style()操作符用来设置或获取选择集中各DOM元素的CSS样式: selection.style(name[,value[,priority]]) style()操 ...
- [资料搜集狂]D3.js数据可视化开发库
偶然看到一个强大的D3.js,存档之. D3.js 是近年来十分流行的一个数据可视化开发库. 采用BSD协议 源码:https://github.com/mbostock/d3 官网:http://d ...
- d3.js:数据可视化利器之 selection:选择集
选择集/selection 选择集/selection是d3中的核心对象,用来封装一组从当前HTML文档中选中的元素: d3提供了两个方法用来创建selection对象: select(selecto ...
- 【 D3.js 进阶系列 — 2.1 】 力学图的事件 + 顶点的固定
本章讨论在力学图中经常使用到的事件( Event ),然后对[p=555">进阶 - 第 2.0 章]的人物关系图进行改进.使用户可以固定拖拽的对象. 在[入门 - 第 9.2 章]和 ...
- 【python可视化系列】python数据可视化利器--pyecharts
学可视化就跟学弹吉他一样,刚开始你会觉得自己弹出来的是噪音,也就有了在使用python可视化的时候,总说,我擦,为啥别人画的图那么溜: [python可视化系列]python数据可视化利器--pyec ...
- MOOC课程信息D3.js动态可视化
版权声明:本文为博主原创文章,转载 请注明出处:https://blog.csdn.net/sc2079/article/details/83153693 - 写在前面 好久没更新博客了,主要还是最近 ...
- 数据可视化利器pyechart和matplotlib比较
python中用作数据可视化的工具有多种,其中matplotlib最为基础.故在工具选择上,图形美观之外,操作方便即上乘. 本文着重说明常见图表用基础版matplotlib和改良版pyecharts作 ...
- Python数据可视化利器Matplotlib,绘图入门篇,Pyplot介绍
Pyplot matplotlib.pyplot是一个命令型函数集合,它可以让我们像使用MATLAB一样使用matplotlib.pyplot中的每一个函数都会对画布图像作出相应的改变,如创建画布.在 ...
随机推荐
- word文档老是出现这个提示-----“发现二义性的名称:TmpDDE”错误
你好 我解决这个问题了,我把appdata目录下的normal.dotm删除了就没问题了 将系统中路径C:\Users\Administrator\AppData\Roaming\Microsoft\ ...
- inline函数出现 undefined reference 错误
原因:你把inline函数的implementation放到cpp文件里肯定要报这个错误 正确的做法:把inline函数的声明和实现都放到header里,例如 // declaration: retu ...
- TortoiseGit 提交代码每次需要输入用户名和密码?
每次用TortoiseGit Pull或者Push的时候都会弹出让输入用户名.密码的框, 很麻烦 ,解决办法如下: 解决办法如下: Right click → TortoiseGit → Settin ...
- EasyDarwin开发出相似于美拍、秒拍的短视频拍摄SDK:EasyVideoRecorder
EasyVideoRecorder Github:https://github.com/EasyDarwin/EasyVideoRecorder EasyVideoRecorder作为一款短视频拍摄的 ...
- hrbustoj 1306:再遇攻击(计算几何,判断点是否在多边形内,水题)
再遇攻击 Time Limit: 1000 MS Memory Limit: 65536 K Total Submit: 253(37 users) Total Accepted: 56(2 ...
- LoadRunner学习---脚本编写(4)(比较重要)
今天接着来翻译http://www.wilsonmar.com/中关于LoadRunner脚本编写部分,下面该翻译脚本编写中一些比较重要的部分了. Web用户Action 在VuGen中,脚本产生的默 ...
- 复习及总结--.Net线程篇(2)
复习总结 上一篇里讲到了使用委托异步调用的方式来使用多线程,这里介绍几个概念 这里贴出来一个关于应用程序域的帖子 http://www.cnblogs.com/firstyi/archive/2008 ...
- iOS开发之 -- NSStringFromSelector的使用
很多时候,我们要触发一个时间,需要设置点击时间,当然了,有很多,比如:按钮,手势,tableview和其他一些空间自带的点击方法, 还有一个就是NSStringFromSelector的使用,废话不多 ...
- 一个简单的ServletContextListener示例
ServletContext可以初始化String类型的参数.但是,如果你希望应用初始化参数是一个数据库DataSource呢?上下文参数只能是String.毕竟,你不能把一个Dog对象塞到XML部署 ...
- 【IIS】IIS 7.0/7.5 无法启动 w3svc 服务
一般情况下,window IIS安装完毕后,会启动C:\inetpub\ 产生 类似C:\inetpub\temp\apppools的文件夹,如果IIS被改动过,此文件夹不会自动生成.需要手动添加. ...