关于setTimeout()的问题

来源:8-5 计时器setTimeout()

web小菜

2017-01-18 16:52

看代码,为什么要执行两次才有用。

<!DOCTYPE HTML>

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8">

<title>计时器</title>


<script type="text/javascript">

  var num=0;

  function startCount() {

    document.getElementById('count').value=num;

    num=num+1;

    setTimeout("startCount()",500) 

  }

    setTimeout("startCount()",500)

</script>

</head>

<body>

<form>

<input type="text" id="count" />

</form>

</body>

</html>


写回答 关注

2回答

  • 绝版女鬼
    2017-01-18 17:33:08

    这个是函数的自己调用自己。

    1、function starCount() 你可以理解成  这个是打豆豆的方法。(请注意还没有打呢)。

    2、下面setTimeout(“startCount()”500)。你可以理解成500微秒打一下豆豆。(开始打了)

    打了一下发现还有一个豆豆 接着打豆豆,打到天荒地老。

    web小菜

    你这解释,有意思,我给满分,哈哈!

    2017-01-19 09:16:57

    共 1 条回复 >

  • 风之流动
    2017-01-18 17:14:37

    第二个才是直接调用

     setTimeout("startCount()",500)

    第一个 setTimeout是循环调用,去掉不会影响

     function startCount() {

        document.getElementById('count').value=num;

        num=num+1;

        setTimeout("startCount()",500) 

      }


JavaScript进阶篇

本课程从如何插入JS代码开始,带您进入网页动态交互世界

468061 学习 · 21891 问题

查看课程

相似问题