我准备了一个小小提示来说明问题here
我在使用d3的退出函数删除dom中的元素时遇到问题。
假设我有一个包含10个元素的数组:
var data = [1 ,4, 5, 6, 24, 8, 12, 1, 1, 20]
我使用此数据使用d3
创建一个简单的水平条形图d3.selectAll('rect')
.data(data)
.enter()
.attr("class", "rectangle")
.attr("stroke", "black")
.attr("stroke-width","1px")
.attr("fill","none")
.attr("x", 0)
.attr("y", function(d, i) { return 25 * i; } )
.attr("width", function(d) { return 22 * d; } )
.attr("height", "20");
现在经过短暂的延迟后,我想修剪我的数据集,所以我剩下的就是
var truncatedData = [4,5]
d3.selectAll('rect')
.data(truncatedData )
.exit()
.transition()
.delay(3000)
.remove();
数据已成功删除,但仍显示前两个元素1,4而不是4,5。
如何从dom中删除[4,5]以外的所有内容?
答案 0 :(得分:19)
默认情况下,d3通过索引而不是值来匹配给.data()
的元素。也就是说,在第二个调用中给它一个两元素数组意味着保留第一个调用中的前两个元素(索引0和1)。
要解决此问题,请提供一个函数来匹配第二次调用.data()
的元素,即
.data([5, 6], function(d) { return(d); })
修正了jsfiddle here。