我正在使用 d3js 拖动行为。这是演示。当我单击元素时,会触发“拖动”和“拖动”事件。即使我不尝试拖动它们,事件仍然会触发。我想在单击项目时调用其他一些函数。只有当我拖动项目时才应该触发拖动事件。那么如何在这里分离出拖动事件和点击事件。
function onDragDrop(dragHandler, dropHandler) {
var drag = d3.behavior.drag();
drag.on("drag", dragHandler)
.on("dragend", dropHandler);
return drag;
}
var d = [{ x: 20, y: 20 }];
var g = d3.select("body").select("svg").data(d).append("g").attr("transform", function (d) { return "translate(" + d.x + "," + d.y + ")"; })
.call(onDragDrop(dragmove, dropHandler));
g.append("rect")
.attr("width", 40)
.attr("height", 40)
.attr("stroke", "red")
.attr("fill","transparent")
.attr("x", "20" )
.attr("y", "20")
g.append("text")
.text("Any Text")
.attr("x", "20" )
.attr("y", "20")
function dropHandler(d) {
alert('dropped');
}
function dragmove(d) {
alert('dragged');
d.x += d3.event.dx;
d.y += d3.event.dy;
d3.select(this).attr("transform", "translate(" + d.x + "," + d.y + ")");
}