>  Q&A  >  본문

为什么有两个setTimeout,分别是什么意思?

var fade = function (node) {
        var level = 1;
        var step = function () {
            var hex = level.toString(16);
            node.style.backgroundColor = "#FFFF" + hex + hex;
            if(level < 15) {
                level += 1;
                setTimeout(step, 100);
            }
        };
        setTimeout(step, 100);
    };
    fade(document.body);

定义一个函数,它设置一个DOM节点为黄色,然后把它渐变为白色

phpcn_u238phpcn_u2382772일 전908

모든 응답(2)나는 대답할 것이다

  • 数据分析师

    数据分析师2017-10-01 00:24:07

    setTimeouts가 두 개 있는 이유는 무엇이며 그 의미는 무엇입니까? -PHP 중국어 웹사이트 Q&A-setTimeouts가 두 개 있는 이유는 무엇이며 그 의미는 무엇입니까? -PHP 중국어 홈페이지 Q&A

    꼭 보고 배워보세요.

    회신하다
    0
  • 阿神

    阿神2017-02-17 13:10:52

    setTimeout只是延时一次, 所以最底下那个,是初始时的延迟,然后执行step函数,然后level还没到15,所以level+1,然后执行setTimeout,然后在level还没达到15之前,一直在调用setTimeout延迟调用step函数,直到最后一次setTimeout执行step时,level=15了,不再执行if条件下的内容~

    회신하다
    0
  • 취소회신하다