一个setInterval的小问题

今天在答疑时发现了一个setInterval的小问题,在这里总结一下。
首先咱们先来看个小例子:
写法一

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>setInterval?!</title> </head> <body> <script> setInterval(move,1000); function move(){ alert(1) } </script> </body> </html>

这是一个最简单的计时器小例子,也是setInterval最标准的写法。咱们再来看看第二种写法~

写法二

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>setInterval?!</title> </head> <body> <script> setInterval("move()",1000); function move(){ alert(1) } </script> </body> </html>

这样写setInterval同样能正常调用move函数,再来看看第3种写法~

写法三

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>setInterval?!</title> </head> <body> <script> setInterval(move(),1000); function move(){ alert(1) } </script> </body> </html>

这种写法能发现move只运行了一次。为什么呢?

原因很简单,setInterval要求第一个参数必须是含Javascript命令的字符串或函数对象,所以setInterval("move()",1000)以及setInterval(move,1000),这两个都是正确的。
而setInterval(move(),1000)呢?
当Javascript运行到这个语句时,会立即执行move这个函数,然后把函数的返回值作为setInterval的第一个参数,而由于move函数没有返回值,实际就相当于setInterval(null, 1000)这个当然就不会运行啦,表面看起来就是move只运行了一次。那么咱们改一改看看。

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>setInterval?!</title> </head> <body> <script> setInterval(move(),1000); function move(){ alert(1) return move; } </script> </body> </html>

这样就OK了~。

小结:
move()和move是不相同的,move()是语句,表示要立即执行这个函数的意思;
move则是一个函数对象,代表了这个函数本身,本身是不会运行的,可以把它赋值给其他对象或作为其他函数的参数。就像咱们写的这个例子,把move赋值给setInterval函数作为参数。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值