为什么出现两次settimeout,如何理解,谢谢

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

慕粉18144024425

2016-12-07 16:59

<!DOCTYPE HTML>

<html>

<head>

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

<title>计时器</title>

</head>

<script type="text/javascript">

  var num=0;

  function startCount() {

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

    num=num+1;  

    setTimeout("startCount()",1000);

  }

    setTimeout("startCount()",1000);

</script>

</head>

<body>

<form>

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

</form>

</body>

</html>


写回答 关注

3回答

  • 我要冲钱
    2016-12-07 19:15:11
    已采纳

    因为你“显示时间”的代码块在函数内,而函数是需要调用才会出效果的,所以函数外的那个setTimeout()就是帮你触发函数的;一但触发到这个函数,函数内的setTimeout()就开始工作了,如此就会实现循环

    暮女神

    请问大神是不是开始之后外面那个setTimeout()就不再执行了?

    2016-12-17 22:30:53

    共 2 条回复 >

  • MeYele
    2017-02-05 15:52:25

    还是有点懵

  • 慕粉1473770682
    2016-12-18 14:36:50

    js是顺序执行的,在执行第一个startCount()时候,已经触发了里面的startCount(),之后应该是在次执行第一个startCount()。那第二个startCount()什么时候执行呢?

JavaScript进阶篇

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

468190 学习 · 21891 问题

查看课程

相似问题