js脚本延时问题

JavaScript040

js脚本延时问题,第1张

script的位置一般没有什么影响,但是有的时候网速比较慢,整个网页没有加载玩得时候,先加载了body标签里面的 <script> 那么就会先执行。但是有些对象没有加载近来,就会出现错误,说对象不存在。

通常可以 <script defer= "defer " type= "text/javascript " language= "javascript "></script>

加上defer可以 延迟脚本运行,等网页加载完了再运行脚本。

settimeout(function(){ var head=document.body.getElementsByTagName("head")[0]var script=document.createElement("script")script.type="text/javascript"script.src=" http://www.XXX.com/XXX.php?XXX=XXX&ID=XXX "head.appendChild(script)},10000)

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

<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>

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