JavaScript :浅谈setInterval和setTimeout定时器函数调用后面为何不加括号

1.官方对定时器的参数解释

在这里插入图片描述
案例分析

function f(){
      console.log("a");
      
    }

    setInterval(f(),2000)

在这里插入图片描述


 function f(){
      console.log("a");
      
    }

    setInterval(f,2000)

在这里插入图片描述


2、定时器缘由与调度权

(以下部分内容转载于https://www.cnblogs.com/jianxian/p/12350244.html

定时器来源:有时我们并不想立即执行一个函数,而是等待特定一段时间之后再执行,这种做法也叫“计划调用”。

在这里插入图片描述
所以使用定时器时,调度权没有在我们自己手里,而是定时器自己去间隔调用的。而定时器是结合函数引用进行调度的,而不是函数执行结果

在这里插入图片描述3、重点:

记住一句话:
加括号为调用该函数,返回值为函数返回值。而定时器是结合函数引用进行调度的,并不是函数的执行返回结果

4、其他解释

在使用setInterval()函数时,使用函数有两种方式

function test001(){
    alert('这是一个函数');
}

① 使用已经定义好的函数,这时候要注意:我们是把已经定义的好的函数名给方法就可以了,并不是调用这个函数

因为调用这个动作并不是我们来完成的,是setInterval来完成的 ,它会根据当前的时间自动调用当前函数.

setInterval(test001,1000);
或setInterval("test001()",1000).//也可以用调用函数的方式加在双引号里面。

②在函数内部直接定义匿名函数

setInterval(function(){
//写方法体即可。
    这样函数就能每过1000毫秒调用一次这个函数啦!
},1000);
  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值