Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/ssl/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
有人能告诉我如何用循环替换下面的javascript代码吗?_Javascript_Function_Loops_Variables_Binding - Fatal编程技术网

有人能告诉我如何用循环替换下面的javascript代码吗?

有人能告诉我如何用循环替换下面的javascript代码吗?,javascript,function,loops,variables,binding,Javascript,Function,Loops,Variables,Binding,我试过这样的说法: 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

我试过这样的说法:

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]); });
与循环中的i不同。我还尝试了stackoverflow.com/questions/750486/javascript-closure-inside-loops-simple-practical-example中的绑定技术

function(d) { 
  return y(d[dataBase[i].columnline]); 
} 
函数createfunc(计数){
返回函数(d){
返回y(d[dataBase[count].columnline]);
};
}
对于(var i=0;i

但这也导致了一个错误。有人能告诉我如何将八行代码组成一个循环吗?

正如上面的一位评论者所说,这几乎肯定是一个范围问题,但如果不看周围的代码,很难确切地说出什么样的范围问题。如果JavaScript中存在范围问题,一个通常的好主意是尽可能多地包装在独立函数中,因为它们都有自己的范围,并且可以在一定程度上充当闭包。也许可以尝试以下方式:

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));
}
函数xFunc(d){
返回函数(d){returnx(d[“Date”])};
}
函数yFunc(d,i){
返回函数(d){returny y(d[dataBase[i].columnline])};
}
对于(var i=0;i

我不知道这是否真的有效,即使有效,也可能有更好的方法来实现关闭。如果您不熟悉立即调用的函数表达式,请检查,并考虑找到一种方法来将它们处理到代码中。它们非常适合防止JavaScript中的范围问题。

您遇到了范围问题,但是如果没有完整的代码,就无法尝试制定解决方案。
,但这也会导致错误。
什么错误?
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));
}
function xFunc(d) {
    return function (d) { return x(d["Date"]) };
}

function yFunc(d, i) {
    return function (d) { return y(d[dataBase[i].columnline]) };
}

for (var i = 0; i < dataBase.length; i++) {

    dataBase[i].valueline = d3.svg.line()
        .x(xFunc(d))
        .y(yFunc(d, i));

}