我创建了一个带有.on("click")
行为的 SVG 元素,并添加了 g 元素,.on("click")
并认为我可以使用它d3.event.stopPropagation()
来防止 SVG 点击事件被 g 点击事件触发。相反,这两个事件继续触发。所以我必须把stopPropagatio
n 放在错误的地方。
svg = d3.select("#viz").append("svg:svg")
.attr("width", 800)
.attr("height", 800)
.on("mousedown", mousedown);
sites = svg.selectAll("g.sites")
.data(json.features)
.enter()
.append("svg:g")
.on("click", siteClick)
;
sites.append("svg:circle")
.attr('r', 5)
.attr("class", "sites")
;
function mousedown() {
console.log("mouseDown");
}
function siteClick(d, i) {
d3.event.stopPropagation();
console.log("siteClick");
}