zoukankan      html  css  js  c++  java
  • javascript之面试for循环

    今天去面试,答题时竟然犯晕。上题:

    for (var i = 0; i < 5; i++) {
        setTimeout(function(){
            console.log(i)
        },1000);    
    };

    我竟然填了,12345。真想去屎。然而真正的答案是,5 个 5。究其原因:for循环执行是很快的。远在定时器的时间到之前,for循环就已经执行完了。然而我今天。。。

    以上。

    还有一题,虽然有些明白了,但还是有些费解的。上题:

    for (var i = 0; i < 5; i++) {
        setTimeout(function(){
            console.log(i);
        },(function(){
            var b = i*1000;
            console.log(b);
            return b;
        })())
    };

    浏览器执行后,0到4000很快输出了,然而输出 5 时,却是1s 输出一个。为什么呢?后来终于想到了。同一时间计时,for循环了5次,setTimeout执行了5次,开了5个定时器,这5个定时器的执行时间分别是1s,2s,3s,4s,5s。却是for循环执行时间太短,瞬间执行完,就约等于同时开了这5个定时器。于是乎,就出现了1s钟出现一次的共出现了5次的 5。

    话说,坑好深啊,一不小心掉进去呀掉进去。。

  • 相关阅读:
    Promise前期准备---区别实例对象与函数对象
    es6之函数参数默认值、字符串方法、for of
    es6之剩余和扩展参数
    es6之解构赋值
    es6之set和map
    前端知识点总结
    jQuery的12种选择器
    前端面试总结
    Closure
    PHP 中 16 个魔术方法详解
  • 原文地址:https://www.cnblogs.com/caicaidandan/p/6692845.html
Copyright © 2011-2022 走看看