typeof、instanceof與constructor

typeof返回一個表達式的數據類型的字符串,返回結果爲js基本的數據類型,包括number,boolean,string,object,undefined,function.javascript

語法: typeof(data) 或 typeof datajava

instanceof則爲判斷一個對象是否爲某一數據類型,或一個變量是否爲一個對象的實例;返回boolean類型.
語法: o instanceof A函數

如下爲綜合實例:spa

 console.log("typeof(1):" + typeof(1));//number
 console.log("typeof(\"abc\"):" + typeof("abc"));//string
 console.log("typeof(true):" +typeof(true));//boolean
 console.log("typeof(2009-2-4):" + typeof(2009-2-4));//number
 console.log("typeof(\"2009-2-4\"):" + typeof("2009-2-4"));//string
 console.log("typeof(m):" + typeof(m));//undefined

 var d=new Date();
 console.log("typeof(d):" + typeof(d));//object

 function Person(){};
 console.log("typeof(Person):" + typeof(Person));//function

 var a=new Array();
 console.log("typeof(a):" + typeof(a));//object
 console.log("a instanceof Array:" + (a instanceof Array)); //true

 var h=new Person();
 var o={};
 console.log("h instanceof Person:" + (h instanceof Person));//true
 console.log("h instanceof Object:" + (h instanceof Object));//true
 console.log("o instanceof Object:" + (o instanceof Object));//true
 console.log(typeof(h));//object

使用typeof的一個很差的地方就是它會把Array還有用戶自定義函數都返回爲object.對象

var j=2;
console.log(typeof(j));//number
console.log("j.constructor:" + j.constructor);//function
console.log(typeof(j.constructor));//function

 

能夠看到js.constructor返回的是一些字符串,你們都應該能看到這是一個function類型,此例爲Number()爲Number對象的構造函數,Number()用於將其參數轉換爲數字number類型,並返回轉換結果(若不能轉換則返回 NaN)。blog

所以在之後的js判斷數據類型時可使用如下方式來獲得其詳細數據類型ip

if((typeof o=="object") && (o.constructor==Number)){}

 這裏還要注意,constructor只能對已有變量進行判斷,而typeof則可對未聲明變量進行判斷(返回undefined)。字符串

相關文章
相關標籤/搜索