search

Home  >  Q&A  >  body text

Please analyze | Why is the output of this JavaScript code 5?

The following code, I thought it would output 1-10, but the output is 5, and it keeps outputting 5. It is an infinite loop. I don’t understand it. Please enlighten me. Thanks!

function initloop() {
    function doLoop(x) {
        i = 3;
        console.log(x);
    }

    for (var i = 0; i < 10; i++) {
        doLoop(i + 1);
    }
}

initloop();
大家讲道理大家讲道理2809 days ago1092

reply all(4)I'll reply

  • 阿神

    阿神2017-05-19 10:42:19

    That i is actually equivalent to being declared in initloop.

    function initloop() {
        var i = 0;
        function doLoop(x) {
            i = 3;
            console.log(x);
        }
        for ( ; i < 10; i++) {
            doLoop(i + 1);
        }
        
    }
    
    initloop();

    Look at it this way, if you think about the function execution process, you should understand.
    Every time it loops, i will be modified to 3 in doloop.
    After doloop is executed, i++ is executed, and the actual parameters passed into the loop should be It's 4 + 1;
    So the console first is 1, and then it keeps outputting 5 in an infinite loop.
    If you want to output 1 - 10 as you want, add var to i in the doloop. Make it a local variable.

    reply
    0
  • 高洛峰

    高洛峰2017-05-19 10:42:19

    The first loop i=0, the doloop actual parameter i+1 is 1, so the first output is 1. Because there is no i variable in the doloop function, it will look for the i variable in the external scope, so i=3 will assign the value of i in the loop body to 3. After the first loop ends, because i<10, i++ is 4. Starting from the second time, i is 4, so the dooloop actual parameter is 5. Because i is assigned a value of 3 every time the dloop function is executed, so i is always less than 10. The result is 1 for the first time, and then prints 5 in a loop.

    reply
    0
  • 为情所困

    为情所困2017-05-19 10:42:19

    First I tried running your code, and the browser got stuck twice... I mourned for my browser...
    For this reason, I discovered that your code is poisonous...

    When actually running, the input is as follows:

    1. The first time in the for loop, i===0, 执行doLoop(1), 因此doLoop函数内部, 形参x===1, 接着又改变了外部i的值, 重置为3, 故此时i===3, 紧接着打印出了x的值, 即1.

    2. When the for loop loops for the second time, because the first loop endsi===3, 发生自增操作, 即i++. 故i最终等于4. 4+1=5, 故执行doLoop(5),本次打印出了5. 函数内部重复上一次的操作, 外部i变量再次被重置为3,本次循环结束后i===5.

    3. When the for loop loops for the third time, the last operation is repeated, i is reset to 3, 再次打印5, 以此类推, 最终外层的for循环失效, 每次i的值都被重置为3 again, and the loop end condition cannot be met. Therefore, the loop cannot exit. Therefore, the browser freezes.

    To summarize, this way of writing is problematic. Try not to change variables outside the function inside the function.

    reply
    0
  • PHP中文网

    PHP中文网2017-05-19 10:42:19

    Every time the loop loops, i is assigned a value of 3, and i in the dloop function is not a private variable, so i in the initloop is assigned a value of 3 every time. The next time i++ is looped, i becomes 4 and passed into the dloop. Naturally, every printed value is 5. After solving it, dloop changes i to 3. i will never be equal to 10, so the loop is endless

    reply
    0
  • Cancelreply