发生此错误的原因是
data.nums
未定义。
你的
data
变量不是包含以下数组的对象:
var data = {
nums: [0.3,0.6,0.8,0.95,0.40,0.20]
}
但是,更确切地说,是一个包含对象的数组:
var data = [
{nums:0.3},
{nums:0.6},
{nums:0.8},
{nums:0.95},
{nums:0.40},
{nums:0.2}
]
为了留住你
r
边码,我们只需要把数据数组本身传递给
selection.data()
并访问
nums
每个基准的特性:
var barHeight = Math.floor(height / data.length);
svg.selectAll('rect')
.data(data)
.enter().append('rect')
.attr('width', function(d) { return d.nums * width; })
.attr('height', barHeight)
.attr('y', function(d, i) { return i * barHeight; })
.attr('fill', 'steelblue');