注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

梦幻雪冰

技在手,能在身,思在脑,从容过生活——陈能堡

 
 
 

日志

 
 

【转载】一个setInterval的小问题  

2014-08-03 11:13:00|  分类: JavaScript |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
本文转载自淡淡De影痕《一个setInterval的小问题》

一个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函数作为参数。

欢迎学习交流----梦幻雪冰淡De影痕
  评论这张
 
阅读(67)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017