我无法使用onClick侦听器来处理dc.barChart。根据{{3}},可点击图表现在应该有一个onClick监听器。但是,我已经尝试了chart.onClick = function和chart.on(“click”,function),没有任何运气。下面是我试图测试监听器是否正常工作的代码。
var hubChart = dc.barChart("#hub-chart");
var dateHub = dateCF.dimension(function(d){ return d.hub;}),
dateHubs = dateHub.group().reduceSum(function(d){
return d.total;
});
var minHub = dateHub.bottom(1)[0].hub;
var maxHub = dateHub.top(1)[0].hub;
hubChart.width(0.40 * window.innerWidth)
.height(350)
.dimension(dateHub)
.group(dateHubs)
.x(d3.scale.linear().domain([minHub, maxHub]))
.elasticY(true)
.elasticX(true)
.brushOn(false);
hubChart.on("preRedraw", function (chart) {
chart.rescale();
});
hubChart.on("preRender", function (chart) {
chart.rescale();
});
hubChart.onClick = function(chart){
console.log(true);
}
hubChart.on("click", function (chart) {
console.log(true);
});
hubChart.render();
只要点击图表,这应该会导致打印到控制台,但不会发生任何事情。
答案 0 :(得分:4)
似乎onClick仅对具有序数X轴的条形图启用。只要您愿意替换内置点击行为,您就可以使用dc对d3选择器的访问来完成同样的事情:
chart.on("renderlet.somename", function(chart) {
chart.selectAll('rect').on("click", function(d) {
console.log("click!", d);
});
});
我打开了一个问题来跟踪问题/请求:https://github.com/dc-js/dc.js/issues/633