selection.on:事件监听操作符

on()操作符可以添加移除选择集中每个 DOM元素的事件监听函数:

  1. 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提供了更好用的方法:

  1. d3.mouse(container)

参数container表示一个HTML元素,d3.mouse()将返回鼠标位置相对于 这个容器元素的x、y坐标。

这意味着对同一个鼠标事件,我们只要传入不同的容器元素,就可以获得鼠标位置 不同的相对位置!

解脱了很多令人烦躁的计算过程,对吧?

参考资料:http://***/course/54fd40cfe564e50d50dcf284/

d3.js:数据可视化利器之 交互行为:响应DOM事件的更多相关文章

  1. d3.js:数据可视化利器之快速入门

    hello,data! 在进入d3.js之前,我们先用一个小例子回顾一下将数据可视化的基本流程. 任务 用横向柱状图来直观显示以下数据: var data = [10,15,23,78,57,29,3 ...

  2. d3.js:数据可视化利器之 修改文档:DOM操作符

    style: CSS样式操作符 style()操作符用来设置或获取选择集中各DOM元素的CSS样式: selection.style(name[,value[,priority]]) style()操 ...

  3. [资料搜集狂]D3.js数据可视化开发库

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

  4. d3.js:数据可视化利器之 selection:选择集

    选择集/selection 选择集/selection是d3中的核心对象,用来封装一组从当前HTML文档中选中的元素: d3提供了两个方法用来创建selection对象: select(selecto ...

  5. 【 D3.js 进阶系列 — 2.1 】 力学图的事件 + 顶点的固定

    本章讨论在力学图中经常使用到的事件( Event ),然后对[p=555">进阶 - 第 2.0 章]的人物关系图进行改进.使用户可以固定拖拽的对象. 在[入门 - 第 9.2 章]和 ...

  6. 【python可视化系列】python数据可视化利器--pyecharts

    学可视化就跟学弹吉他一样,刚开始你会觉得自己弹出来的是噪音,也就有了在使用python可视化的时候,总说,我擦,为啥别人画的图那么溜: [python可视化系列]python数据可视化利器--pyec ...

  7. MOOC课程信息D3.js动态可视化

    版权声明:本文为博主原创文章,转载 请注明出处:https://blog.csdn.net/sc2079/article/details/83153693 - 写在前面 好久没更新博客了,主要还是最近 ...

  8. 数据可视化利器pyechart和matplotlib比较

    python中用作数据可视化的工具有多种,其中matplotlib最为基础.故在工具选择上,图形美观之外,操作方便即上乘. 本文着重说明常见图表用基础版matplotlib和改良版pyecharts作 ...

  9. Python数据可视化利器Matplotlib,绘图入门篇,Pyplot介绍

    Pyplot matplotlib.pyplot是一个命令型函数集合,它可以让我们像使用MATLAB一样使用matplotlib.pyplot中的每一个函数都会对画布图像作出相应的改变,如创建画布.在 ...

随机推荐

  1. word文档老是出现这个提示-----“发现二义性的名称:TmpDDE”错误

    你好 我解决这个问题了,我把appdata目录下的normal.dotm删除了就没问题了 将系统中路径C:\Users\Administrator\AppData\Roaming\Microsoft\ ...

  2. inline函数出现 undefined reference 错误

    原因:你把inline函数的implementation放到cpp文件里肯定要报这个错误 正确的做法:把inline函数的声明和实现都放到header里,例如 // declaration: retu ...

  3. TortoiseGit 提交代码每次需要输入用户名和密码?

    每次用TortoiseGit Pull或者Push的时候都会弹出让输入用户名.密码的框, 很麻烦 ,解决办法如下: 解决办法如下: Right click → TortoiseGit → Settin ...

  4. EasyDarwin开发出相似于美拍、秒拍的短视频拍摄SDK:EasyVideoRecorder

    EasyVideoRecorder Github:https://github.com/EasyDarwin/EasyVideoRecorder EasyVideoRecorder作为一款短视频拍摄的 ...

  5. hrbustoj 1306:再遇攻击(计算几何,判断点是否在多边形内,水题)

    再遇攻击 Time Limit: 1000 MS    Memory Limit: 65536 K Total Submit: 253(37 users)   Total Accepted: 56(2 ...

  6. LoadRunner学习---脚本编写(4)(比较重要)

    今天接着来翻译http://www.wilsonmar.com/中关于LoadRunner脚本编写部分,下面该翻译脚本编写中一些比较重要的部分了. Web用户Action 在VuGen中,脚本产生的默 ...

  7. 复习及总结--.Net线程篇(2)

    复习总结 上一篇里讲到了使用委托异步调用的方式来使用多线程,这里介绍几个概念 这里贴出来一个关于应用程序域的帖子 http://www.cnblogs.com/firstyi/archive/2008 ...

  8. iOS开发之 -- NSStringFromSelector的使用

    很多时候,我们要触发一个时间,需要设置点击时间,当然了,有很多,比如:按钮,手势,tableview和其他一些空间自带的点击方法, 还有一个就是NSStringFromSelector的使用,废话不多 ...

  9. 一个简单的ServletContextListener示例

    ServletContext可以初始化String类型的参数.但是,如果你希望应用初始化参数是一个数据库DataSource呢?上下文参数只能是String.毕竟,你不能把一个Dog对象塞到XML部署 ...

  10. 【IIS】IIS 7.0/7.5 无法启动 w3svc 服务

    一般情况下,window IIS安装完毕后,会启动C:\inetpub\ 产生 类似C:\inetpub\temp\apppools的文件夹,如果IIS被改动过,此文件夹不会自动生成.需要手动添加. ...