javascript中檢測對象的類型的運算符有:typeof、constructor、instanceof。javascript
typeof:typeof是一個一元運算符,返回結果是一個說明運算數類型的字符串。如:"number","string","boolean","object","function","undefined"(可用於判斷變量是否存在)。 但 typeof 的能力有限,其對於Date、RegExp、Array類型返回的都是"object"。因此它只在區別對象和原始類型的時候纔有用。要區一種對象類型和另外一種對象類型,必須使用其餘的方法。java
instanceof 運算符:instanceof 運算符要求其左邊的運算數是一個對象,右邊的運算數是對象類的名字或構造函數。若是 object 是 class 或構造函數的實例,則 instanceof 運算符返回 true。若是 object 不是指定類或函數的實例,或者 object 爲 null,則返回 false。instanceof方法能夠判斷變量是不是數組類型,可是隻限同一全局環境以內,在一個頁面有多個iframe的狀況下,instanceof失效。數組
constructor 屬性: JavaScript中,每一個對象都有一個constructor屬性,它引用了初始化該對象的構造函數,經常使用於判斷未知對象的類型。如給定一個求知的值 經過typeof運算符來判斷它是原始的值仍是對象。若是是對象,就能夠使用constructor屬性來判斷其類型。函數
Object.prototype.toString.call():該方法是目前爲止發現的判斷一個對象類型的最好的辦法。prototype
擴展一下,用於檢測各類對象類型:code
var is ={ types : ["Array", "Boolean", "Date", "Number", "Object", "RegExp", "String", "Window", "HTMLDocument"] }; for(var i = 0, c; c = is.types[i ++ ]; ){ is[c] = (function(type){ return function(obj){ return Object.prototype.toString.call(obj) == "[object " + type + "]"; } )(c); } alert(is.Array([])); // true alert(is.Date(new Date)); // true alert(is.RegExp(/reg/ig)); // true