本人的我的博客为: www.ourd3js.com javascript
csdn博客为: blog.csdn.net/lzhlzz html
转载请注明出处,谢谢。java
这一节介绍怎样进行对话的操做,如鼠标单击,鼠标滑过等。浏览器
对一个被选择的元素,加入对话操做,代码例如如下:app
.on("click", function(){ } )函数可以是无名函数。也可以是自定义的函数。上面代码监听的是鼠标单击的事件。但鼠标在被选择对象上单击时,就会调用函数 function 。
常用的事件(event)有:svg
svg.selectAll("rect") .data(dataset) .enter() .append("rect") .attr("x", function(d,i){ return 30 + xScale(i); } ) .attr("y",function(d,i){ return 50 + 500 - yScale(d) ; }) .attr("width", function(d,i){ return xScale.rangeBand(); }) .attr("height",yScale) .attr("fill","red") .on("click",function(d,i){ d3.select(this) .attr("fill","green"); }) .on("mouseover",function(d,i){ d3.select(this) .attr("fill","yellow"); }) .on("mouseout",function(d,i){ d3.select(this) .transition() .duration(500) .attr("fill","red"); });上面的代码加入了鼠标点击( click ),鼠标移入( mouseover )。鼠标移出( mouseout )三个操做。
上面的操做的函数中都调用了 d3.select(this) , 这是表示选择当前的元素,this 是当前的元素,因为在事件中一般要改变被点击的元素等,因此常有这段代码,要记住。函数