web-dev-qa-db-ja.com

ループ内で関数を作成しないでください

この場合のjslintエラーを解決する正しい方法は何ですか?これを使用するオブジェクトにゲッター関数を追加しています。ループ内で関数を作成せずにこれを行う方法がわかりません。

for (var i = 0; i<processorList.length; ++i) {
   result[i] = {
       processor_: timestampsToDateTime(processorList[i]),
       name_: processorList[i].processorName,
       getLabel: function() { // TODO solve function in loop.
            return this.name_;
       }
   };
}
66

関数をループの外側に移動します。

function dummy() {
    return this.name_;
}
// Or: var dummy = function() {return this.name;};
for (var i = 0; i<processorList.length; ++i) {
   result[i] = {
       processor_: timestampsToDateTime(processorList[i]),
       name_: processorList[i].processorName,
       getLabel: dummy
   };
}

...または、ファイルの先頭で loopfuncオプション を使用してメッセージを無視します。

/*jshint loopfunc:true */
101
Rob W