woe*_*ler 49 javascript jquery d3.js
我有一个D3直方图,我在其上附加了一个'onclick'事件:
...
var bar = svg.selectAll(".bar")
.data(data)
.enter().append("g")
.attr("class", "bar")
.attr("transform", function(d) { return "translate(" + x(d.x) + "," + y(d.y) + ")"; })
.on('mouseover', tip.show)
.on('mouseout', tip.hide)
.on('click', function(d,i){ //do stuff });
...
Run Code Online (Sandbox Code Playgroud)
这完全符合预期.我还想在图表的背景上添加一个'onclick'事件(即图表中不是条形图的任何地方),但我遇到了麻烦.我尝试过以几种方式附加事件,但在每种情况下,这个新事件似乎都会覆盖我的条形图:
一些尝试:
$("svg:not('.bar')").on("click", function(){ //do stuff });
$("g:not('.bar')").on("click", function(){ //do stuff });
var svg = d3.select("#histogram_block").append("svg")
.attr("width", width + margin.left + margin.right)
.attr("height", height + margin.top + margin.bottom)
.append("g")
.attr("transform", "translate(" + margin.left + "," + margin.top + ")")
.on("click", function(d,i){
if (d) { //do stuff}
else { //do stuff }
};
Run Code Online (Sandbox Code Playgroud)
我假设有一种方法可以在初始化时将事件处理程序添加到SVG对象,但我不知道正确的方法.
Lar*_*off 60
事件实际上没有被覆盖,但两者都被触发 - onclick
SVG和bar 的处理程序.要防止这种情况,请使用该.stopPropagation()
方法(请参阅文档).代码如下所示:
rect.on("click", function() {
console.log("rect");
d3.event.stopPropagation();
});
Run Code Online (Sandbox Code Playgroud)