定时器 setInterval 有一个有名函数 fn1,setInterval(fn1, 500)与 setInterval(fn1(), 500)有什么区别?

简介: 定时器 setInterval 有一个有名函数 fn1,setInterval(fn1, 500)与 setInterval(fn1(), 500)有什么区别?

setInterval 是 JavaScript 中用于定时执行函数的方法。它的基本语法是 setInterval(function, delay),其中 function 是你想要定期执行的函数,delay 是每次执行之间的延迟时间(以毫秒为单位)。



对于 setInterval(fn1, 500) 和 setInterval(fn1(), 500),两者之间的主要区别在于函数调用的方式。

  1. setInterval(fn1, 500)
  • 在这种情况下,fn1 是一个函数引用,它告诉 setInterval 每隔 500 毫秒调用一次 fn1。每次调用时,它都会执行 fn1 函数的新实例。
  • 这是正确的方式,因为它允许 setInterval 周期性地调用 fn1 函数,而不需要立即执行它。
  1. setInterval(fn1(), 500)
  • 在这种情况下,fn1() 会立即执行,并将 fn1 函数的返回值(如果有的话)设置为 setInterval 的回调。
  • 这通常不是你想要的,因为这意味着 fn1 函数会在设置定时器时立即执行一次,而不是每隔 500 毫秒执行一次。
  • 如果 fn1 没有返回值(即它是 void),则 setInterval 将无法执行任何内容,因此定时器将不会工作。



因此,当你想要使用 setInterval 时,应该使用 setInterval(fn1, 500) 的形式,以确保 fn1 函数被周期性地调用,而不是立即执行。

相关文章
|
7月前
|
JSON 数据格式
setInterval函数的function与()=>区别——解决Cannot readproperty‘XXXXXXX‘of undefined异常
setInterval函数的function与()=>区别——解决Cannot readproperty‘XXXXXXX‘of undefined异常
68 0
|
8月前
|
JavaScript
vue 定时器:setInterval和setTimeout使用实例及区别
vue 定时器:setInterval和setTimeout使用实例及区别
187 0
|
8月前
|
JavaScript 调度
setTimeout和setImmediate以及process.nextTick的区别?
setTimeout和setImmediate以及process.nextTick的区别?
131 0
|
JavaScript 前端开发
window.setTimeout() 和window.setInterval() 的用法与区别
window.setTimeout() 和window.setInterval() 的用法与区别
115 0
|
JavaScript 前端开发
js 定时器用法详解——setTimeout()、setInterval()、clearTimeout()、clearInterval()
写在前面: 在js应用中,定时器的作用就是可以设定当到达一个时间来执行一个函数,或者每隔几秒重复执行某段函数。这里面涉及到了三个函数方法:setInterval()、setTimeout()、clearInterval(),本文将围绕这三种函数的用法,来实现定时器的功能,需要的朋友可以过来参考下,喜欢的可以点波赞,或者关注一下本人,希望对大家有所帮助。 定时器的应用需求: 1.设定一个时间,当时间到达的时候执行函数————比如:倒计时跳转页面等等。 2.每隔一段时间重复执行某段函数————比如抢票软件,比如设定500毫秒就重复刷新一次页面等等。 倒计时跳转实现demo:
663 0
js 定时器用法详解——setTimeout()、setInterval()、clearTimeout()、clearInterval()
|
前端开发 JavaScript Java
函数防抖节流原理及封装+闭包+call/apply/bind
函数防抖节流原理及封装+闭包+call/apply/bind
109 0
|
JavaScript
js中两种定时器,setTimeout和setInterval的区别
js中两种定时器,setTimeout和setInterval的区别
91 0
|
Web App开发 JavaScript 前端开发
Javascript定时器(三)——setTimeout(func, 0)
setTimeout(func, 0)可以使用在很多地方,拆分循环、模拟事件捕获、页面渲染等
Javascript定时器(三)——setTimeout(func, 0)