一、傳統(tǒng)方法不為人所知的細(xì)節(jié) 毫無(wú)疑問(wèn),在判斷函數(shù)類型時(shí),我們使用的是typeof方法,比如: 復(fù)制代碼 " /> 亚洲成年人免费网站,日韩欧美一级,在线电台收听

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

Javascript 判斷函數(shù)類型完美解決方案

但是,有一些細(xì)節(jié)并不為我們所熟知。John Resig 在分析了這些細(xì)節(jié)之后,為我們提供了一個(gè)完美的解決方案,本文將作詳細(xì)介紹:

一、傳統(tǒng)方法不為人所知的細(xì)節(jié)
毫無(wú)疑問(wèn),在判斷函數(shù)類型時(shí),我們使用的是typeof方法,比如:
復(fù)制代碼 代碼如下:
function fn(){
//content
}
alert(typeof fn)//結(jié)果是"function"。

但是,該方法在一些瀏覽器中并不是像我們想像的那樣工作。

1、Firefox2和Firefox3
在這兩個(gè)瀏覽器中,用typeof檢測(cè)HTML對(duì)象元素的類型,得到是一個(gè)不精確的“function”結(jié)果,而不是“object”,如HTMLDocument。如:
復(fù)制代碼 代碼如下:
alert(typeof HTMLDocument);
//在Firefox2中結(jié)果是"function";
//在Firefox3中結(jié)果是"object";

2、Firefox2
對(duì)于正則表達(dá)式,在該瀏覽器中返回的結(jié)果是“function”(在Firefox3中結(jié)果是“object”),如:
復(fù)制代碼 代碼如下:
var reg = /test/;
alert(typeof reg);
//在Firefox2中結(jié)果是"function";
//在Firefox3中結(jié)果是"object";

注:本人在safari中測(cè)試,其結(jié)果也是“function”。
3、IE6和IE7
在IE中對(duì)DOM元素使用typeof方法,得到的結(jié)果是“object”。如:
復(fù)制代碼 代碼如下:
alert(typeof document.getElementsByTagName("body")[0].getAttribute);
//結(jié)果是"object"

4、Safari 3
safari認(rèn)為DOM元素的NodeList是一個(gè)函數(shù),如:
復(fù)制代碼 代碼如下:
alert(typeof document.body.childNodes);
//結(jié)果是"function"

很明顯,如果你要測(cè)試一個(gè)對(duì)象是否為函數(shù),使用typeof方法并不能從真正意義上保證測(cè)試結(jié)果。那么,我們就需要一種在所有瀏覽器中都能保證測(cè)試結(jié)果的解決方案。我們知道function本身有apply()和call()兩種方法,但這兩個(gè)方法在IE中存在問(wèn)題的函數(shù)中并不存在,試試下面的測(cè)試:
復(fù)制代碼 代碼如下:
alert(typeof document.getElementsByTagName("body")[0].getAttribute.call)
//在IE中結(jié)果是"undefined"

顯然,我們不能利用這兩個(gè)方法。

二、完美解決方案及實(shí)現(xiàn)過(guò)程
John Resig為我們提供了一個(gè)完美的解決方案,這個(gè)復(fù)雜但很穩(wěn)定的判斷一個(gè)對(duì)象是否為函數(shù)的方法如下:
復(fù)制代碼 代碼如下:
function isFunction( fn ) {
return !!fn && !fn.nodeName && fn.constructor != String &&
fn.constructor != RegExp && fn.constructor != Array &&
/function/i.test( fn + "" );
}

這個(gè)函數(shù)首先保證測(cè)試的對(duì)象存在,并將其序列化成含有“function”的字符串,這個(gè)是我們檢測(cè)的基礎(chǔ)(fn.constructor != String,fn.constructor != Array, and fn.constructor != RegExp)。另外,我們需要保證聲明的函數(shù)不是一個(gè)DOM節(jié)點(diǎn)(fn.nodeName)。然后,我們就可以作toString測(cè)試。如果我們將一個(gè)函數(shù)轉(zhuǎn)換成字符串,在一個(gè)瀏覽器中(fn+"")給我們的結(jié)果就像這樣“function name(){...}”。現(xiàn)在,判斷它是否為函數(shù)就很簡(jiǎn)單,僅僅只需要判斷字符串中是否包含單詞“function”。這很神奇,對(duì)于任何有問(wèn)題的函數(shù),在所有瀏覽器中都能得到我們所需要的結(jié)果。這個(gè)函數(shù)較之于傳統(tǒng)的方法,運(yùn)行速度有些不盡人意,作者建議我們保守使用。

John Resig 是jQuery庫(kù)的開(kāi)發(fā)者,相信使用該庫(kù)的朋友們對(duì)該庫(kù)簡(jiǎn)潔的語(yǔ)法和優(yōu)秀的性能并不陌生。作者除追求代碼簡(jiǎn)潔和性能高效之外,其盡善盡美的精神也讓人嘆服。如果你是一個(gè)完美主義者,相信此文對(duì)你很有幫助。

JavaScript技術(shù)Javascript 判斷函數(shù)類型完美解決方案,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 麻豆文化传媒一区二区 | 麻豆E奶女教师国产精品 | 亚洲AV国产福利精品在现观看 | 小学生偷拍妈妈视频遭性教育 | 最近中文字幕mv手机免费高清 | 国产精品成人不卡在线观看 | 国产成人高清亚洲一区app | 午夜DJ国产精华日本无码 | 国产精品久久久久久久AV下载 | 久久亚洲AV成人无码国产漫画 | 亚洲精品久久无码AV片WWW | 91麻豆精品一二三区在线 | 97精品在线 | 国产亚洲精品视频亚洲香蕉视 | 把极品白丝老师啪到腿软 | 国产午夜精品理论片在线 | 中文字幕亚洲欧美日韩2o19 | 美女pk精子2小游戏 美女MM131爽爽爽 | 2021年国产精品久久 | 恋夜影院安卓免费列表uc | 久久精品国产欧美成人 | 国产Av男人的天堂精品良久 | 国产A级毛片久久久久久久 国产a级黄色毛片 | 韩日午夜在线资源一区二区 | 麻花豆传媒剧国产免费mv观看 | WWW亚洲精品久久久乳 | 动漫AV纯肉无码AV电影网 | 日本高清免费一本视频在线观看 | 成人片在线播放 | 亚洲一品AV片观看五月色婷婷 | 精品无码三级在线观看视频 | 久久精品嫩草影院免费看 | 91进入蜜桃臀在线播放 | 久久这里的只有是精品23 | 午夜黄视频 | 又色又爽又黄gif动态视频 | 老板揉搓秘书丰满大乳 | 国产亚洲欧美在线观看三区 | 白丝美女被狂躁免费漫画 | 国产欧美二区综合 | 亚洲.欧美.中文字幕在线观看 |