Array.isArray()
let a = [1,2,3] Array.isArray(a);//true
此方法為 ES5新增方法 ,兼容Es5之外不支持的問題
if (!Array.isArray) { Array.isArray = function(arg) { return Object.prototype.toString.call(arg) === '[object Array]'; }; }
Object.prototype.toString.call()判斷數據類型
1.判斷基本類型:
Object.prototype.toString.call(null);//”[object Null]” Object.prototype.toString.call(undefined);//”[object Undefined]” Object.prototype.toString.call(“abc”);//”[object String]” Object.prototype.toString.call(123);//”[object Number]” Object.prototype.toString.call(true);//”[object Boolean]”
2.判斷原生引用類型:
函數類型
Function fn(){console.log(“test”);} Object.prototype.toString.call(fn);//”[object Function]”
日期類型
var date = new Date(); Object.prototype.toString.call(date);//”[object Date]”
數組類型
var arr = [1,2,3]; Object.prototype.toString.call(arr);//”[object Array]”
正則表達式
var reg = /[hbc]at/gi; Object.prototype.toString.call(arr);//”[object RegExp]”
自定義類型
function Person(name, age) { this.name = name; this.age = age; } var person = new Person("Rose", 18); Object.prototype.toString.call(person); //”[object Object]”
很明顯這種方法不能准確判斷person是Person類的實例,而只能用instanceof 操作符來進行判斷,如下所示:
console.log(person instanceof Person);//輸出結果為true
3.判斷原生JSON對象:
var isNativeJSON = window.JSON && Object.prototype.toString.call(JSON); console.log(isNativeJSON);//輸出結果為”[object JSON]”說明JSON是原生的,否則不是
原文作者:keepup~
原文地址:https://www.cnblogs.com/cn-chy-com/p/11524980.html