首页 >

JavaScript 定时器 SetTimeout之定时刷新窗口和关闭窗口(代码超简单)【javascript】

web前端|js教程

JavaScript 定时器 SetTimeout之定时刷新窗口和关闭窗口(代码超简单)【javascript】

JavaScript ,SetTimeout,刷新关闭窗口
web前端-js教程
JavaScript 定时器 SetTimeout之定时刷新窗口和关闭窗口(代码超简单)_javascript技巧
读书网源码,vscode cpu占用,ubuntu 阿里源,tomcat重启脚本,sqlite 数据获取,一般网页设计什么价格,带数据库的网站,租用托管服务器,织梦自动推送插件,mvvm前端框架,爬虫猫眼,php漏洞,seo优化工具,springboot数组查询,nav标签,网站自动充值接口,dw中文网页模板下载,discuzx3.2手机模板,怎么侵入别人织梦后台,批量生成静态页面,办公oa系统与经营管理系统,vc 程序的声音lzw
废话不多说了,直接给大家贴代码了。
c 拼图游戏 源码,mac 命令行安装vscode,蓝牙耳机 ubuntu,电脑装tomcat,sqlite 大字段,网页设计css教程,如何部署到服务器,js侧栏消息通知插件,kit前端框架,远古爬虫脑,php文件域,江西seo优化公司,springboot日志包,qq点赞网站源码,js 网页图标,蓝色清爽医疗pdf模板,html5 大转盘 带后台,jq页面滚动到顶部,网站后端管理系统,java中怎样记录程序被运行的次数lzw
// 每隔五秒定时刷新当前窗口setTimeout("self.location.reload();",5000);//js 定时关闭窗口(ie和FF中测试过)//6秒后自动关闭当前窗口setTimeout("window.opener=null;window.close()",6000);

下面给大家介绍下javascript定时器使用

12套ASP企业网站源码 PC版 手机版,ubuntu制作矿池,爬虫用ip代理,chr(101) php,云盾seolzw
使用定时器实现JavaScript的延期执行或重复执行 window对象提供了两个方法来实现定时器的效果,分别是

window.setTimeout()和window.setInterval。其中前者可以使一段代码在指定时间后运行;而后者则可以使一段代码每过指定时间就运行一次。 它们的原型如下:

window.setTimeout(expression,milliseconds); window.setInterval(expression,milliseconds);

其中expression可以是字符串,也可以是函数名。是字符串的时候可以带参数,函数名不能带参数,如果带上参数就直接执行函数了,不会延时。

 function hello (){ console.log('I am dada'); //alert('I am ' + name);//setTimeout(arguments.callee,2000); } setTimeout(hello,5000);//5秒后执行 setTimeout('hello()',3000);//3秒后执行setTimeout(hello(),8000);//立刻执行

第一种情况是函数名,但是带不了参数

第二种情况是字符串,可执行的js代码,可以带参数,但是性能上比函数名差

第三种是调用函数,直接执行

所以如果想要穿参数,但是又不想通过字符串的形式调用,可以自己来写一个方法:

function _hello(_name){ return function(){ hello2(_name); } } setTimeout(_hello(name),7000);//立刻执行

A、setTimeout

setTimeout(function(){//要执行的代码 },200);

指隔200ms后,定时器代码被添加到队列中,等待JavaScript进程空闲后,代码才执行

B、setInterval

1、上面代码是指每隔200ms就创建一个执行代码的定时器
2、当使用setInterval时,仅当(在队列中)没有该定时器的任何其他代码实例时,才将定时器代码添加到队列中,引用JavaScript高级程序设计第二版书中语句(即:当前一个定时器代码执行时,紧跟后面的第一个定时器代码将添加到队列中,等待执行,再后面的定时器代码不会添加到队列中)

用setInterval来执行反复的行为的时候会遇到一个问题:

当定时器代码执行时间(假如需要600ms才执行完)超过指定间隔(这里是200ms),那么某些定时器代码就会被跳过(即后面的定时器代码不会被添加到队列中),前一个定时器代码执行完毕后,队列中的定时器代码立刻执行,各定时器之间的代码执行没有间隔。这时,需要使用链式setTimeout。

这样做的好处是:前一个定时器要执行的代码执行完且等待200ms后,才创建一个新的定时器,并把定时器代码添加到队列中执行即:不会出现定时器代码被跳过的情况;定时器之间的代码执行可以有间隔(根据自己设置)。

setTimeout(function(){//要执行的代码 setTimeout(arguments.callee,2000); },2000);setInterval(function(){//要执行的代码 },200);


  • 暂无相关文章