【发布时间】:2014-08-22 10:46:22
【问题描述】:
dataBase[0].valueline = d3.svg.line()
.x(function(d) { return x(d["Date"]); })
.y(function(d) { return y(d[dataBase[0].columnline]); });
dataBase[1].valueline = d3.svg.line()
.x(function(d) { return x(d["Date"]); })
.y(function(d) { return y(d[dataBase[1].columnline]); });
dataBase[2].valueline = d3.svg.line()
.x(function(d) { return x(d["Date"]); })
.y(function(d) { return y(d[dataBase[2].columnline]); });
dataBase[3].valueline = d3.svg.line()
.x(function(d) { return x(d["Date"]); })
.y(function(d) { return y(d[dataBase[3].columnline]); });
dataBase[4].valueline = d3.svg.line()
.x(function(d) { return x(d["Date"]); })
.y(function(d) { return y(d[dataBase[4].columnline]); });
dataBase[5].valueline = d3.svg.line()
.x(function(d) { return x(d["Date"]); })
.y(function(d) { return y(d[dataBase[5].columnline]); });
dataBase[6].valueline = d3.svg.line()
.x(function(d) { return x(d["Date"]); })
.y(function(d) { return y(d[dataBase[6].columnline]); });
dataBase[7].valueline = d3.svg.line()
.x(function(d) { return x(d["Date"]); })
.y(function(d) { return y(d[dataBase[7].columnline]); });
我已经尝试过声明:
for (var i = 0; i < dataBase.length; i++) {
dataBase[i].valueline = d3.svg.line()
.x(function(d) { return x(d["Date"]); })
.y(function(d) { return y(d[dataBase[i].columnline]); });
}
但这不起作用,因为
function(d) {
return y(d[dataBase[i].columnline]);
}
与循环中的 i 不同。我还尝试了 stackoverflow.com/questions/750486/javascript-closure-inside-loops-simple-practical-example 中的绑定技术
function createfunc(count) {
return function(d) {
return y(d[dataBase[count].columnline]);
};
}
for (var i = 0; i < dataBase.length; i++) {
dataBase[i].valueline = d3.svg.line()
.x(function(d) { return x(d["Date"]); })
.y(createfunc(i));
}
但这也导致了错误。谁能告诉我如何将八行代码变成一个循环?
【问题讨论】:
-
您遇到范围问题,但没有完整代码无法尝试解决
-
But that also resulted in an error as well.什么错误?
标签: javascript function loops variables binding