|
Js代碼
復制代碼 代碼如下:
alert(typeof null); // "object"
alert(typeof []); // "object"
2、instanceof操作符。此操作符檢測對象的原型鏈是否指向構造函數的prototype對象,恩,聽起來不錯,應該可以解決我們的數組檢測問題:
Js代碼
復制代碼 代碼如下:
var arr = [];
alert(arr instanceof Array); // true
3、對象的constructor屬性。除了instanceof,我們還可以利用每個對象都具有constructor的屬性來判斷其類型,于是乎我們可以這樣做:
Js代碼
復制代碼 代碼如下:
var arr = [];
alert(arr.constructor == Array); // true
貌似后兩個解決方案是無懈可擊的,但真的是這樣么?天有不測風云,當你在多個frame中來回穿梭的時候,令人沮喪的問題出現了:
Js代碼
復制代碼 代碼如下:
var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
xArray = window.frames[window.frames.length-1].Array;
var arr = new xArray(1,2,3); // [1,2,3]
// 哎呀!
arr instanceof Array; // false
// 哎呀呀!
arr.constructor === Array; // false
由于每個iframe都有一套自己的執行環境,跨frame實例化的對象彼此是不共享原型鏈的,因此導致上述檢測代碼失效!怎么辦怎么辦??嗯,Javascript是動態語言,或許萬金油“鴨式辨型”(duck type)可以助我們一臂之力“如果它走起路來像鴨子,叫起來也像鴨子,那就當他是鴨子吧”,同理,可以檢測某些數組對象特有的能力來做判斷,這個法子已經有人用了,比如Prototype框架,來看看它實現的Object.isArray方法:
Js代碼
復制代碼 代碼如下:
isArray: function(object) {
return object != null && typeof object == "object" &&
'splice' in object && 'join' in object;
}
isArray:”object,你有splice、join這兩個數組特有的方法嗎?”
object:“嗯,沒錯我有!”
isArray:“好吧,那你就是個數組了,哪怕你是冒充的, 主站蜘蛛池模板: 日韩高清在线观看 | 久久国际精品 | 成人免费视频观看视频 | 欧美国产视频 | 毛片99| 久久综合一区二区 | 欧美视频1区 | 国产精品一区二区精品 | 欧美黄色性生活视频 | www.日韩高清| 久草视频在线播放 | 新超碰97 | 亚洲欧洲成人在线 | 精品在线一区 | 国产精品一区二区三区在线 | 亚洲视频手机在线 | 国产福利资源在线 | 电影91久久久 | 亚洲协和影视 | 日本视频中文字幕 | 一级做a毛片 | 精品国产乱码久久久久久a丨 | 久久精品国产久精国产 | 国内91在线 | 久久精品国产久精国产 | 亚洲一区二区三区四区av | 成人午夜av| 精品1区 | 91性高湖久久久久久久久_久久99 | 欧美一级免费黄色片 | 91在线视频播放 | 亚洲国产精品一区二区久久 | 国产精品一卡 | 区一区二区三在线观看 | 欧美日韩国产高清视频 | 亚洲36d大奶网 | 欧美多人在线 | 日韩欧美中文字幕在线观看 | 欧美日韩在线一区二区 | 免费1区2区3区 | 日韩精品在线免费 |