一、typeof判斷數據類型(判斷數組跟對象都返回object)
console.log(typeof null); // "object" console.log(typeof function () { return 1; }); // "function" console.log(typeof '夢龍小站'); // "string" console.log(typeof 1); // "number" console.log(typeof a); // "undefined" console.log(typeof undefined); // "undefined" console.log(typeof []); // "object" console.log(typeof NaN); // "number" console.log(typeof {}); // "object"
二、instanceof判斷對象的原型鏈是否是指向構造函數的prototype
var arr = [1,2,3,1]; console.log(arr instanceof Array)//true
三、對象的constructor屬性
var arr = [1,2,3,1]; console.log(arr.constructor === Array)//true
四、Object.prototype.toString.call(arr)
利用對象的toString可以准確判斷是什么類型,call()改變this指向,這里是借用Object的方法,然后有人可能會問為什么不直接用arr.toString而要借用Object的方法,
我們看下面
console.log(Object.prototype.toString.call("jerry"));//[object String] console.log(Object.prototype.toString.call(12));//[object Number] console.log(Object.prototype.toString.call(true));//[object Boolean] console.log(Object.prototype.toString.call(undefined));//[object Undefined] console.log(Object.prototype.toString.call(null));//[object Null] console.log(Object.prototype.toString.call({name: "jerry"}));//[object Object] console.log(Object.prototype.toString.call(function(){}));//[object Function] console.log(Object.prototype.toString.call([]));//[object Array] console.log(Object.prototype.toString.call(new Date));//[object Date] console.log(Object.prototype.toString.call(/\d/));//[object RegExp] console.log(Object.prototype.toString.call(new Person));//[object Object]
直接用toString
console.log("jerry".toString());//jerry console.log((1).toString());//1 console.log([1,2].toString());//1,2 console.log(new Date().toString());//Wed Dec 21 2016 20:35:48 GMT+0800 (中國標准時間) console.log(function(){}.toString());//function (){} console.log(null.toString());//error console.log(undefined.toString());//error
因為toString為Object原型上的方法,而Array、Function都是Object的實例,實例重新改寫了原型上的toString方法,不同的對象調用toString方法,調用的是改寫之后的方法
(轉成各種類型的字符串),而不會調用Object原型上的toString()方法,因此直接調用不能判斷對象類型
var arr=[1,2,3]; console.log(Array.prototype.hasOwnProperty("toString"));//true console.log(arr.toString());//1,2,3 delete Array.prototype.toString;//delete操作符可以刪除實例屬性 console.log(Array.prototype.hasOwnProperty("toString"));//false console.log(arr.toString());//"[object Array]"
我們可以看到,刪除實例上的toString方法后調用的是Object原型上的toString()方法,返回對象類型
五、es6的方法——Array.isArray()
Array.isArray([]) //true
六、看好多博客說用length判斷,這個其實不准確
var obj={a:1} var arr = [] console.log(obj.length)//undefined console.log(arr.length)//0 obj.length = 1 console.log(obj.length)//1
對象可以直接添加length這個屬性,就無法區分了