【JavaScript】关于 setInterval() 调用函数方法的一次实验
实验主题:
setInterval() 方法是 JS 中比较常用的一个方法。setInterval() 方法可以按照指定的周期 ( 毫秒 ) 来调用函数方法或计算表达式。
setInterval() 方法会不停地调用函数,直到 clearInterval() 被调用或窗口关闭。由 setInterval() 返回的 ID 值可用作 clearInterval() 方法的参数。
注:1000 毫秒 = 1秒
setInterval() 语法:
setInterval(code, millisec, lang)
| 参数 | 描述 |
|---|---|
| code | 必须。要调用的函数或要执行的代码串。 |
| millisec | 必须。周期性的执行或调用 code 之间的时间间隔。 |
| lang | 可选。JScript | VBScript | JavaScript |
setInterval() 返回值:number值,是一个可以传递给 Window.clearInterval() 从而取消对 code 的周期性执行的值。测试代码:
var id = setInterval("foo1()",100);
alert(typeof(id));
setInterval() 作为 JavaScript 的一个计时事件,可以使代码在一个设定的时间内反复的执行多次,而不是在函数被调用后立即执行,这就是我们的计时事件。JavaScript 的另一个计时事件是 setTimeout(),他们两个都是 HTML DOM Window 对象的方法。
因为是 Window 的对象方法,所以加前缀 " window. " 对调用没有什么影响。另外,clearInterval() 也是 Window 的对象方法。
实验测试:
var foo1 = new Function("return alert('!!!')");//正常运行,而且刚开始时不会执行
setInterval(foo1,2000);//注意:Function不能写成function
var foo2 = new Function("alert('!!!')");//正常运行,而且刚开始时不会执行
setInterval(foo2,2000);
var foo3 = new Function(return alert('!!!'));//错误,抛出异常:"Uncaught SyntaxError: Unexpected token return"
setInterval(foo3,2000);
var foo4 = new Function(alert('!!!'));//刚开始运行一次,没有异常
setInterval(foo4,2000);
setInterval(function(){alert("!!!")},2000);//正常运行,而且刚开始时不会执行
setInterval(foo5(),2000);//刚开始运行一次,没有异常,执行一次的原因可能是载入过程中执行
function foo5(){
alert("!!!");
};
function foo6(){
alert("!!!");
};
setInterval(foo3(),2000);//注释掉这里不会运行函数,所以并不是载入脚本时自动执行的函数,而是被setInterval()调用执行了一次
setInterval("foo7()",2000);//正常运行,而且刚开始时不会执行
function foo7(){
alert("!!!");
};
function foo8(){//正常运行,而且刚开始时不会执行
alert("!!!");
};
setInterval("foo8()",2000);
setInterval("foo9",2000);
function foo9{//错误,抛出异常:"Uncaught SyntaxError: Unexpected token {"
alert("!!!");
};
function foo10(){//不会执行调用函数
alert("!!!");
};
setInterval("foo10",2000);
function foo11(){//正常运行,而且刚开始时不会执行
alert("!!!");
};
setInterval(foo11,2000);
实验总结:
要想通过 setInterval() 方法正常调用执行函数,有三种方法:
- 通过 new 创建一个函数字面量,如 foo1
- 声明一个函数,然后通过字符串的形式调用,如 foo7
- 如果函数没有参数,则可以 foo11 的形式调用函数
附:如果需要停止计时事件,则需要这样:
var id = setInterval("foo1()",100);
function foo2(){
clearInterval(id);
}
停止计时事件需要给出被停止的事件的 id。
【JavaScript】关于 setInterval() 调用函数方法的一次实验的更多相关文章
- thinkphp模版调用函数方法
原文:thinkphp模版调用函数方法 {变量|函数1|函数2|函数3=参数1,参数2,参数3,###} ###为第4个参数,代表变量替换为第4个参数 举例: {$username|substr=0, ...
- (二)学习JavaScript之setInterval和clearInterval方法
参考:http://www.w3school.com.cn/jsref/met_win_setinterval.asp HTML DOM Window 对象 定义和用法 setInterval() 方 ...
- JS按照指定的周期来调用函数方法
setInterval() 方法可按照指定的周期(以毫秒计)来调用函数或计算表达式. setInterval() 方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭.由 s ...
- setTimeOut(),和setInterVal()调用函数加不加括号!!!
直接在ready中调用其他方法,会提示缺少对象的错误,解决方法如下: 方法1. 应用jQuery的扩展可以解决这个问题. $(document).ready(function(){ $.extend( ...
- 理解JavaScript的立即调用函数表达式(IIFE)
首先这是js的一种函数调用写法,叫立即执行函数表达式(IIFE,即immediately-invoked function expression).顾名思义IIFE可以让你的函数立即得到执行(废话). ...
- source insight 如何建工程--以及快捷方式查找调用函数方法
在source insight的view菜单中点出relation window,然后右键点relation window,选relation window properties,然后把view re ...
- 【javascript】onblur调用函数失效问题记录
在处理页面上一个失焦效果时遇到了 xxxx is not a function 这样的错误,但函数确实有定义成功 ,经过测试发现是 id 值与函数名一致导致的问题,但是产生的原因没有找到详细的解释 ...
- pycharm中调用函数方法自动补全p,m,c,v,f分别是什么意思
p:parameter 参数m:method 方法c:class 类v:variable 变量f:function 函数
- vue input,textarea失去焦点调用函数方法
<input type="number" class="num" value="1" @blur.prevent="chan ...
随机推荐
- 使用jQuery发送ajax
我们先看一下js的原生ajax 直接进入代码,我们先准备好servlet,之后不会改动,所以先看一下. package cn.curry.servlet; import com.alibaba.fas ...
- BUG数量和项目成本
这篇文章,不是讨论怎么提升程序员的能力避免BUG,因为程序员的能力不足造成的BUG,短期是无法避免的.这里主要探讨的是因为程序员疏忽大意和不良的开发习惯,产生的低级BUG,对项目成本影响. 首先了解下 ...
- PHP中调用SVN命令更新网站方法(解决文件名包含中文更新失败的问题)
想说写一个通过网页就可以执行 SVN 升级的程序,结果并不是我想得那样简单,有一些眉角需要注意的说. 先以 Apache 的用户帐号执行 SVN checkout,这样 Apache 才有 SVN 的 ...
- iOS优化
load妙用 aop面向切面编程 NSNumber Or Int @()适配64位 经过漫长时间的学习 你终于掌握了iOS大法 你找到了份iOS开发的工作 信誓旦旦的要开始你的coding生涯 老板对 ...
- Outlook 客户端无法通过 MAPI over HTTP协议 连接
随着Exchange 版本更新升级,是否进行验证客户端建立MapiHttp连接所需的服务器设置已正确配置.即使服务器,负载均衡器和反向代理的所有设置都正确,您可能会遇到连接到Exchange Serv ...
- Redis相关注意事项
本文介绍了五个使用Redis使用时的注意事项.如果你在使用或者考虑使用Redis,你可以学习一下下面的一些建议,避免遇到以下提到的问题. 一.配置相关注意事项 1.涉及到内存的单位注意添加 b 1k ...
- MySQL——数据库和 SQL 概念&&MySQL的安装
数据库和 SQL 概念 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,它的产生距今已有六十多年.随着信息技术和市场的发展,数据库变得无处不在:它在电子商务.银行系统等众多领域都 ...
- C++容器类-vector
vecto之简单应用: #include<vector> #include<iostream> using namespace std; int main() { vector ...
- Linux curl命令中,HTTP 302处理
在Linux中使用curl命令时,偶尔会遇到一些URL跳转到新的URL,即HTTP中的3XX(redirection,重定向 ). $curl -s -I $URL > log 这时在返回的报文 ...
- 【细节题 离线 树状数组】luoguP4919 Marisa采蘑菇
歧义差评:但是和题意理解一样了之后细节依然处理了很久,说明还是水平不够…… 题目描述 Marisa来到了森林之中,看到了一排nn个五颜六色的蘑菇,编号从1-n1−n,这些蘑菇的颜色分别为col[1], ...