In JavaScript, what are specific reasons why creating functions within a loop can be computationally wasteful?

╄→尐↘猪︶ㄣ 提交于 2019-12-01 04:53:13

问题


In JavaScript, what are specific reasons why creating functions within a loop can be computationally wasteful?

On page 39 of JavaScript the Good Parts, Douglas Crockford states, "Avoid creating functions within a loop. It can be computationally wasteful". I can't seem to figure out why creating functions within a loop would be anymore wasteful than outside.


回答1:


Because you're creating several Function objects instead of reusing just one.

Example of creating an identical function...

for (var i = 0; i < 10; i++) {
    // v--creating identical function in each iteration.
    (function(j) {
        var el = document.createElement('a');
        el.onclick = function() { alert(j); };
        document.body.appendChild(el);
    })(i);
}

Example of reusing a named function...

for (var i = 0; i < 10; i++) {
    var el = document.createElement('a');
      // ----------v---calling a reusable function
    el.onclick = createHandler(i);
    document.body.appendChild(el);
}

function createHandler(j) {
    return function() { alert(j); };
}

The two examples have the same outcome, but the second doesn't require the overhead of making two functions during the loop. Instead it creates just the one handler.




回答2:


Creating a function can use a lot of resources. As functions are in fact objects, the code has to actually create a new function object each time, it can't just create it once and then just reuse it.

Creating a function inside a loop usually means that you will be creating a lot of functions instead of just creating a single function outside the loop.

So, it's just a matter of not doing something resource intensive inside a loop if you can instead do it once outside the loop. When it comes to functions, they can often be created outside the loop without changing the logic of the code.



来源:https://stackoverflow.com/questions/10834740/in-javascript-what-are-specific-reasons-why-creating-functions-within-a-loop-ca

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!