先來一段代碼,大家猜猜在各種瀏覽器下的結果會是怎么樣的呢? 復制代碼 代碼如下: function f() " /> 国内精品一级毛片免费看,国产精品人妻无码久久久奥特曼,色99久久久久高潮综合影院

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

setTimeout與setInterval在不同瀏覽器下的差異

。(新手可能認為setTimeout與setInterval是Javascript函數,這是錯誤的。新手容易將Javascript對象函數與DOM對象方法混淆。)

先來一段代碼,大家猜猜在各種瀏覽器下的結果會是怎么樣的呢?
復制代碼 代碼如下:
function f(){
var s = 'arguments.length:'+arguments.length+'; ';
for(var i=0,n=arguments.length;i< n;i++){
s += ' ['+i+']:'+arguments[i]+'; ';
}
alert(s);
}
setTimeout(f,500,"Javascript","AAA")

我這里要探討的,不是什么時候該用哪一個,而是探討這兩個方法在各瀏覽器中的差異。
原先我一直沒覺得這兩個方法會有什么烏龍,一個偶然的機會讓我得知了,現在整理一下寫出來和大家分享。
因為setTimeout與setInterval的參數和用法是一樣的,只是功能不同,所以,為了省事,我下面只以setTimeout為例進行說明以及舉例。
setTimeout被最經常用到的形式大概是如下2種樣子的:
復制代碼 代碼如下:
iTimerID = setTimeout(strJsCode, 50) //strJsCode為一個包含js代碼的字符串
iTimerID = setTimeout(objFunction, 50) //objFunction為一個函數對象

第一種調用方式是傳包含js代碼的字符串,這種方式的好處是簡潔,但壞處是運行效率差,而且不利于語法解析,有潛在風險,更重要的是,處理比較復雜的內容比較費勁,這一點和eval的弊端是一致的。
所以,我們認為,通常應當采用第二種方式調用為好。(后面我的例子均采用第2種調用方式)

現在來揭曉開頭那一段代碼在各種瀏覽器下的結果:
IE(6,7,8)是: arguments.length:0;
Opera(6,7,8)是: arguments.length:2; [0]:Javascript; [1]:AAA;
Firefox(3.0)是: arguments.length:3; [0]:Javascript; [1]:AAA; [2]:-15;
竟然有這么大的差別,還真是“你唱你的曲,我哼我的調”!
Firefox(3.0)下,得出的最后一個數字是不特定的,有時候是0,有時候是一個負數,這問題后面再說。
(一)IE系列中的setTimeout
首先,我們看看微軟出的DHTML參考手冊中是如何說的:
setTimeout Method
Evaluates an expression after a specified number of milliseconds has elapsed.
Syntax
iTimerID = window.setTimeout(vCode, iMilliSeconds [, sLanguage])
Parameters
vCode Required. Variant that specifies the function pointer or string that indicates
the code to be executed when the specified interval has elapsed.
iMilliSeconds Required. Integer that specifies the number of milliseconds.
sLanguage Optional. String that specifies one of the following values:
JScript Language is JScript.
VBScript Language is VBScript.
JavaScript Language is JavaScript.
MSDN上關于setTimeout的說明:
http://msdn.microsoft.com/en-us/library/ms536753(VS.85).ASPx
也就是說,setTimeout接收3個參數,第3個參數表示腳本語言的類型,如果你再傳入更多的參數,是無意義的。
因此,在IE中,以下兩種都是對的。
setTimeout('alert(1)', 50);
setTimeout('msgbox "終止、重試、忽略,您看著辦吧。", vbAbortRetryIgnore + vbDefaultButton2, "告訴您"', 50, 'VBScript');
(二)Mozilla系列中的setTimeout
我們看看Mozilla官方網站上 Gecko DOM Reference 手冊中是如何說的:
window.setTimeout
Summary
Executes a code snippet or a function after specified delay.
Syntax
var timeoutID = window.setTimeout(func, delay, [param1, param2, ...]);
var timeoutID = window.setTimeout(code, delay);
前兩個參數都一樣,沒差別,從第三個參數就不同了。
因為目前只有IE瀏覽器支持多種語言的腳本,其它瀏覽器只支持js腳本所以不需要傳語言類型的參數。
Mozilla把傳給setTimeout的第3個以及更后面的更多參數依次的傳給前面的func做為參數。
Firefox, Opera, Safari, Chrome等等也都是如此。
但是注意到,Mozilla上說了他家的setTimeout有一個叫做"Lateness" argument的BUG.
"Lateness" argument
Functions invoked by setTimeout are passed an extra "lateness" argument in Mozilla,
i.e., the lateness of the timeout in milliseconds. (See bug 10637 and bug 394769.)
這就是開頭那個例子中,Firefox(3.0)下有一個烏龍數字的根源。
Mozilla上關于setTimeout的說明:
https://developer.mozilla.org/en/DOM/window.setTimeout
(三)其它瀏覽器系列(Opera, Safari, Chrome)中的setTimeout
和Mozilla系列中的基本一樣,但是沒有Mozilla系列中的多一個參數的BUG.

武林外傳:使用setTimeout的小技巧
(1)IE中給setTimeout中的調用函數傳參數
上面的分析可知,IE是不支持在setTimeout中給被調用的函數傳參數的,為了瀏覽器世界的和諧,我們可以把函數調用參數包裹進新的匿名函數中。示例:
復制代碼 代碼如下:
function f(a){
alert(a);
}
// setTimeout(f,50,'hello'); //用于非IE
setTimeout(function(){f('hello')},50); //通用
var str='hello';
setTimeout(function(){f(str)},50); //通用

(2)this問題
setTimeout調用的函數被執行時的上下文是全局,而不再是調用setTimeout方法時的上下文。所以,setTimeout的第一個參數的函數被執行時其this是指向window的,如果需要保留調用setTimeout方法時的this,就需要把當時的this傳進去。示例:
復制代碼 代碼如下:
function Person(name){
this.name=name;
var f=function(){alert('My name is '+this.name)};
// setTimeout(f,50); //錯誤
var THIS=this;
setTimeout(function(){f.apply(THIS)},50); //正確,通用
setTimeout(function(){f.call(THIS)},50); //正確,通用
}
new Person('Jack');

要說的就這些了。
發帖子不是腦力活,其實是體力活,組織文字,寫例子,排版,這些沒技術含量的事情是最累人最耗時間的。

JavaScript技術setTimeout與setInterval在不同瀏覽器下的差異,轉載需保留來源!

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

主站蜘蛛池模板: 欧美在线看费视频在线 | 大睾丸内射老师 | 嫩草伊人久久精品少妇AV网站 | 秋霞最新高清无码鲁丝片 | 恋夜影视列表免费安卓手机版 | 亚洲高清中文字幕 | 亚洲免费在线视频观看 | 99国产在线视频有精品视频 | 麻豆国产精品AV色拍综合 | 国产 高清 无码 在线播放 | 99国产精品人妻无码免费 | 回复术士人生重启在线观看 | 亚洲精品美女久久777777 | 国产女人视频免费观看 | 久久久久国产一级毛片高清片 | 成人中文字幕在线 | 青草伊人网 | 精品国产国产精2020久久日 | 亚洲午夜精品A片久久WWW解说 | 亚洲男人片片在线观看 | 午夜国产在线观看 | 一本道无码字幕在线看 | 做暖免费观看日本 | 国语对白嫖老妇胖老太 | 色翁荡息又大又硬又粗又爽电影 | 永久免费看mv网站入口 | 国产最新进精品视频 | 高清日本片免费观看 | 2019午夜福利757视频第12集 | 视频一区视频二区在线观看 | 国产亚洲精品线观看不卡 | 99精品国产免费久久久久久下载 | 色戒床震视频片段 | 国产成人精品在视频 | 一道精品视频一区二区 | 青青青草国产 | 成年人在线视频免费观看 | 国产精品爽黄69天堂A片 | 女人被躁到高潮嗷嗷叫免费 | 69SEX久久精品国产麻豆 | 亚洲色欲H网在线观看 |