JS中实现等待一段时间之后开始定时循环执行某个方法?

JavaScript029

JS中实现等待一段时间之后开始定时循环执行某个方法?,第1张

下面是代码示例:

方法1:

$(function(){

var

handler

=

function(){

}

var

timer

=

setInterval(

handler

,

5000)

//每5秒调用一次方法

var

clear

=

function(){

clearInterval(timer)

//清理时间

})

方法2:

function

methodJS(){

alert("你好!我是方法!")

}

function

Start(){

setInterval(methodJS,

5000)

}

setTimeout(Start,

7000)//延迟7秒开始周期回调

方法3:

window.onload

=

function(){

setTimeout(fun,5000)

}

function

Start(){

//这里是你要执行的方法!

}

楼上的只是等待一秒后执行相应的函数,但要"继续执行后面的程序"(同一个函数)就不行了

<script language="javascript">

/*Javascript中暂停功能的实现

Javascript本身没有暂停功能(sleep不能使用)同时 vbscript也不能使用doEvents,故编写此函数实现此功能。

javascript作为弱对象语言,一个函数也可以作为一个对象使用。

比如:

function Test(){

alert("hellow")

this.NextStep=function(){

alert("NextStep")

}

}

我们可以这样调用 var myTest=new Test()myTest.NextStep()

我们做暂停的时候可以吧一个函数分为两部分,暂停操作前的不变,把要在暂停后执行的代码放在this.NextStep中。

为了控制暂停和继续,我们需要编写两个函数来分别实现暂停和继续功能。

暂停函数如下:

*/

function Pause(obj,iMinSecond){

if (window.eventList==null) window.eventList=new Array()

var ind=-1

for (var i=0i<window.eventList.lengthi++){

if (window.eventList[i]==null) {

window.eventList[i]=obj

ind=i

break

}

}

if (ind==-1){

ind=window.eventList.length

window.eventList[ind]=obj

}

setTimeout("GoOn(" + ind + ")",iMinSecond)

}

/*

该函数把要暂停的函数放到数组window.eventList里,同时通过setTimeout来调用继续函数。

继续函数如下:

*/

function GoOn(ind){

var obj=window.eventList[ind]

window.eventList[ind]=null

if (obj.NextStep) obj.NextStep()

else obj()

}

/*

该函数调用被暂停的函数的NextStep方法,如果没有这个方法则重新调用该函数。

函数编写完毕,我们可以作如下册是:

*/

function Test(){

alert("hellow")

Pause(this,3000)//调用暂停函数

this.NextStep=function(){

alert("NextStep")

}

}

Test()

</script>

以前收藏的,很经典!!!