我正在尝试使用D3展示一张漂亮的折线图。我遇到的问题是数据格式。
以下是我的数据(以示例形式):
var data = [
{
label: "name",
data: [[14444123, 0.012321312],
[14444123, 0.012321312],
[14444123, 0.012321312], ...]
},{
label: "another name",
data: [[14444123, 0.012321312],
[14444123, 0.012321312],
[14444123, 0.012321312], ...]
}
];
每个条目都包含其名称以及一个数据属性,其中包含点数组(每个点表示为数组,其中item [0]是x时间戳,item [1]是值)。
我的问题是它没有正确工作。
这是我现在拥有的D3代码:
var w = options.width,
h = options.height,
p = options.padding,
x = d3.scale.linear()
.domain([0, 1])
.range([0, w]),
y = d3.scale.linear()
.domain([options.ydomainstart, options.ydomainend])
.range([h, 0]);
var vis = d3.select(options.element)
.data(data)
.append("svg:svg")
.attr("width", w + p * 2)
.attr("height", h + p * 2)
.append("svg:g");
vis.append("svg:line")
.attr("stroke", '#808080')
.attr("x1", p)
.attr("x2", p)
.attr("y1", 0)
.attr("y2", h - p);
vis.append("svg:line")
.attr("stroke", '#808080')
.attr("x1", p)
.attr("x2", w)
.attr("y1", h - p)
.attr("y2", h - p);
var rules = vis.selectAll("g.rule")
.data(data)
.enter()
.append("svg:text")
.attr("x", w - p)
.attr("y", function(d, i) { return 15 + i*12; })
.attr("text-anchor", "end")
.attr("font-size", 12)
.attr("fill", function(d, i) { return defaultColors[i % 5]; })
.text(function(d) { return d.label;});
var lines = rules.data(function(d, i) {
return d.data;
})
.append("svg:path")
.attr("stroke", function(d, i) { return defaultColors[i % 5]; })
.attr("d", d3.svg.line()
.x(function(d) {
return x(d[0]);
})
.y(function(d) {
return y(d[1]);
}));
我遇到的问题出现在代码的这一部分:
.x(function(d) {
return x(d[0]);
})
.y(function(d) {
return y(d[1]);
}));
'd' 内的数据并不是点数组 [x, y],而是每个数组中的每个值。
也就是说,在第一个项目上,d 包含 x 坐标,在第二个项目上,它有 y 坐标,在第三个项目上,它包含下一个点的 x 坐标,以此类推。
就像它递归地进入数组,然后再对其中每个值进行操作。
我不知道该如何解决这个问题。
map
方法已被弃用,应使用datum
方法。 - Christian-G