ajax timeout 与浏览器默认timeout,window_setTimeout和setInterval的浏览器兼容性分析,无意中测试AJAXRequest浏览器兼 - phpStudy...

setTimeout和setInterval的浏览器兼容性分析

无意中测试AJAXRequest浏览器兼容性的时候,发现AJAXRequest.update方法在某些情况下在IE里有问题,经过测试找到是setTimeout和setInterval的问题。

问题出现在当调用AJAXRequest.update方法时,如果带了更新间隔及更新次数,那么在IE下面就会出现问题,具体表现为带了更新间隔时是函数工作,带上更新次数时函数无法在更新指定次数后停止执行。

测试几个例子之后找到了问题所在,在IE里,setTimeout和setInterval是不支持参数传递的。

演示地址:http://www.xujiwei.cn/demo/usetimer/

在Netscape的JavaScript参考中找到setTimeout的语法如下:

复制代码 代码如下:

setTimeout

Evaluates an expression or calls a function once after a specified number of milliseconds elapses.

语法

setTimeout(expression, msec)

setTimeout(function, msec, arg1, ..., argN)

参数

expression A string containing a JavaScript expression.

msec A numeric value or numeric string, in millisecond units.

function Any function.

arg1, ..., argN (Optional) The arguments, if any, passed to function.

第二种使用方法就是定义了一个定时器,在执行时function时,将把调用setTimeout时定义的参数传递给function,但在IE中,并不支持这种方式的调用,也就是在执行function的时候,函数并没有接收到这些参数。如下面的例子:

复制代码 代码如下:

function show(str) {

alert("my site: "+str);

}

setTimeout(show,100,"www.xujiwei.cn");

在Firefox和Opera里,浏览器都能正确的弹出提示框显示字符串“my site: www.xujiwei.cn”,而在IE里,显示的则是“my site: undefined”,说明函数show并没有接收到参数str,所以显示出来就是一个未定义变量。

当然,如果在函数内部使用的变量是全局变量时,就不必要考虑这些问题,如:

复制代码 代码如下:

function show() {

// url是全局变量,函数正确执行

alert("my site: "+url);

}

var url="www.xujiwei.cn";

setTimeout(show,100);

这段代码在IE和Firefox里都能正常工作,显示出“my site: www.xujiwei.cn”。

在变量是全局变量的情况下,可以使用语句段的方式来调用setTimeout,即使用第一种语法:

复制代码 代码如下:

function show(str) {

// url是全局变量,函数正确执行

alert("my site: "+str);

}

var url="www.xujiwei.cn";

setTimeout("show(url);",100);

因为变量url是全局变量,因此定时器执行所定义的语句段“show(url);”能正确传递参数,但是如果url不是全局变量,而是一个局部变量时,执行结果就会出错了:

复制代码 代码如下:

function show(str) {

// url是全局变量,函数正确执行

alert("my site: "+str);

}

function test() {

var url="www.xujiwei.cn";

setTimeout("show(url);",100);

}

test();

此时就会出错了,在函数test执行时,会提示url未定义,在执行定义的语句段“show(url);”时,上下文已经脱离了函数test,而url是在函数test内部定义的,所以在执行函数test的时候,变量url已经释放了。

如果要在setTimeout里面使用局部变量,并且解决在IE里的setTimeout不支持参数传递的问题,可以使用匿名函数,即在调用setTimeout时定义一个匿名函数,在这个函数内部进行原来需要进行的操作。

复制代码 代码如下:

function show(str) {

// url是全局变量,函数正确执行

alert("my site: "+str);

}

function test() {

var url="www.xujiwei.cn";

setTimeout(function(){show(url);},100);

}

test();

在上面的例子中,调用setTimeout时定义了一个匿名函数,它的函数体是“show(url);”,因为已经定义了函数,所以在定时器调用这个函数时,变量url还是有引用的,因些函数可以正确执行,显示出字符串“my site: www.xujiwei.cn”。

总的来说,使用setTimeout或者setInterval时需要注意以下几点:

1. 定义定时器时如果是使用的表达示,那么其中的变量应该是全局变量,或者是一个直接的值,而不能是局部变量。

2. 定义定时器时如果是定义的调用函数,那么应该只写函数名,而不能加括号,如果加了就是定义返回值了。

3. 在IE里使用定时器时不能传递参数。

4. 如果要在IE里使用定时器时传递参数,可以使用匿名函数,在函数体中调用原来该调用的函数。

如有错误还请指正。相关阅读:

让人期待的2011年度最佳 jQuery 插件分享

CSS 循序渐进(二)字的艺术

jQuery.Switchable整合插件用途介绍

使用Oracle SQL trace时需要注意的问题

JavaScript中两个感叹号的作用说明

php实现的MySQL通用查询程序

基于jQuery的表格操作插件

用jscript实现新建和保存一个word文档

浅析PHP水印技术

JavaScript 事件的一些重要说明

Windows Server 2008下高效域管理体验

用PHP实现多级树型菜单

javascript:完全容错和浏览器自动最大化

PHP 配置open_basedir 让各虚拟站点独立运行

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值