天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

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的時候,函數并沒有接收到這些參數。如下面的例子:
復制代碼 代碼如下:
<script type="text/Javascript">
function show(str) {
    alert("my site: "+str);
}
setTimeout(show,100,"www.xujiwei.cn");
</script>

在Firefox和Opera里,瀏覽器都能正確的彈出提示框顯示字符串“my site: www.xujiwei.cn”,而在IE里,顯示的則是“my site: undefined”,說明函數show并沒有接收到參數str,所以顯示出來就是一個未定義變量。
當然,如果在函數內部使用的變量是全局變量時,就不必要考慮這些問題,如:
復制代碼 代碼如下:
<script type="text/Javascript">
function show() {
    // url是全局變量,函數正確執行
    alert("my site: "+url);
}
var url="www.xujiwei.cn";
setTimeout(show,100);
</script>

這段代碼在IE和Firefox里都能正常工作,顯示出“my site: www.xujiwei.cn”。
在變量是全局變量的情況下,可以使用語句段的方式來調用setTimeout,即使用第一種語法:
復制代碼 代碼如下:
<script type="text/Javascript">
function show(str) {
    // url是全局變量,函數正確執行
    alert("my site: "+str);
}
var url="www.xujiwei.cn";
setTimeout("show(url);",100);
</script>

因為變量url是全局變量,因此定時器執行所定義的語句段“show(url);”能正確傳遞參數,但是如果url不是全局變量,而是一個局部變量時,執行結果就會出錯了:
復制代碼 代碼如下:
<script type="text/Javascript">
function show(str) {
    // url是全局變量,函數正確執行
    alert("my site: "+str);
}
function test() {
    var url="www.xujiwei.cn";
    setTimeout("show(url);",100);
}
test();
</script>

此時就會出錯了,在函數test執行時,會提示url未定義,在執行定義的語句段“show(url);”時,上下文已經脫離了函數test,而url是在函數test內部定義的,所以在執行函數test的時候,變量url已經釋放了。
如果要在setTimeout里面使用局部變量,并且解決在IE里的setTimeout不支持參數傳遞的問題,可以使用匿名函數,即在調用setTimeout時定義一個匿名函數,在這個函數內部進行原來需要進行的操作。
復制代碼 代碼如下:
<script type="text/Javascript">
function show(str) {
    // url是全局變量,函數正確執行
    alert("my site: "+str);
}
function test() {
    var url="www.xujiwei.cn";
    setTimeout(function(){show(url);},100);
}
test();
</script>

在上面的例子中,調用setTimeout時定義了一個匿名函數,它的函數體是“show(url);”,因為已經定義了函數,所以在定時器調用這個函數時,變量url還是有引用的,因些函數可以正確執行,顯示出字符串“my site: www.xujiwei.cn”。
總的來說,使用setTimeout或者setInterval時需要注意以下幾點:
1. 定義定時器時如果是使用的表達示,那么其中的變量應該是全局變量,或者是一個直接的值,而不能是局部變量。
2. 定義定時器時如果是定義的調用函數,那么應該只寫函數名,而不能加括號,如果加了就是定義返回值了。
3. 在IE里使用定時器時不能傳遞參數。
4. 如果要在IE里使用定時器時傳遞參數,可以使用匿名函數,在函數體中調用原來該調用的函數。

如有錯誤還請指正。

JavaScript技術setTimeout和setInterval的瀏覽器兼容性分析,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 爱啪国产精品视频在线 | 伊人影院香蕉久在线26 | 古代荡乳尤物H妓女调教 | 色宅男看片午夜大片免费看 | 高清视频在线观看SEYEYE | 99精品视频在线观看免费 | 国产在线高清视频无码不卡 | 天天摸夜添狠狠添高 | 白丝制服被啪到喷水很黄很暴力 | 俄罗斯XBXBXB兽交 | 99久久久无码国产AAA精品 | 中文字幕午夜乱理片 | 亚洲精品久久久久久偷窥 | 精品无码国产自产在线观看水浒传 | 成人国内精品久久久久影院 | 第一次处破女完整版电影 | 亚洲视频无码中字在线 | 免费A级毛片无码鲁大师 | 果冻传媒完整免费网站在线观看 | 国产国拍亚洲精品永久软件 | 日韩一卡二卡三卡四卡免费观在线 | 饥渴难耐的浪荡艳妇在线观看 | 国产精品色午夜视频免费看 | 男生jj插入女生jj | 亚洲AV久久久噜噜噜噜 | 热久久视久久精品2015 | 小雪奶水涨翁工帮吸的推荐语录 | 国产精品永久免费视频 | 国产成人免费a在线视频app | adc影院欢迎您大驾光临入口 | 红色机尾快播 | 扒开老师大腿猛进AAA片软件 | 日本熟妇多毛XXXXX视频 | 后入式狂顶免费视频 | 理论片午午伦夜理片2021 | 毛片亚洲毛片亚洲毛片 | 啦啦啦WWW在线观看免费高清版 | 国产激情精品久久久久久碰 | www.绿巨人| 一区二区三区无码被窝影院 | 暖暖视频在线观看高清... |