【 D3.js 进阶系列 — 6.0 】 拖拽的应用(Drag)

本文深入探讨D3.js中的拖拽行为,通过实例讲解如何使用d3.behavior.drag()定义拖拽行为,以及如何结合dragstart、drag和dragend事件实现元素的动态移动。通过绘制圆并应用拖拽功能,读者可以实践并体验拖拽交互的效果。
摘要由CSDN通过智能技术生成

拖拽(Drag)是交互式中很重要的一种,本文将讲解拖拽的使用方法。

1. drag的定义

D3中可用 d3.behavior.drag() 来定义 drag 行为。

		var drag = d3.behavior.drag()
						.on("drag", dragmove); 
						
		function dragmove(d) {	
			d3.select(this)
			  .attr("cx", d.cx = d3.event.x )
			  .attr("cy", d.cy = d3.event.y );
		}

第 2 行表示当 drag 事件发生后即调用 dragmove 函数。除了 drag 事件之外,还有 dragstart 和 dragend 事件,这一点在【进阶 - 第 2.1 章】中有过类似的叙述。

dragmove()里,出现了 d3.event.x 和 d3.event.y 两个变量,这是当前鼠标的位置。我们后面将绘制圆,这里的意思是把圆重新绘制到当前鼠标所在处。

2. 绘制圆

绘制圆的方法相信大家都很熟悉了。最后在圆的选择集中使用 call 函数,调用刚才定义的 drag 行为即可。call函数我们前面说过,即将选择集自身作为参数,传递给 drag 函数。

		var circles
  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值