今天小編給大家分享的是js判斷一個對象是否是數組(函數)的方法,很多人都不太了解,今天小編為了讓大家更加了解js,所以給大家總結了以下內容,一起往下看吧。一定會有所收獲的哦。

1、typeof操作符
實例:
// 數值
typeof 37 === 'number';
// 字符串
typeof '' === 'string';
// 布爾值
typeof true === 'boolean';
// Symbols
typeof Symbol() === 'symbol';
// Undefined
typeof undefined === 'undefined';
// 對象
typeof {a: 1} === 'object';
typeof [1, 2, 4] === 'object';
// 下面的例子令人迷惑,非常危險,沒有用處。避免使用它們。
typeof new Boolean(true) === 'object';
typeof new Number(1) === 'object';
typeof new String('abc') === 'object';
// 函數
typeof function() {} === 'function';從上面的實例我們可以看出,利用typeof除了array和null判斷為object外,其他的都可以正常判斷。
2、instanceof操作符 和 對象的constructor 屬性
這個操作符和JavaScript中面向對象有點關系,了解這個就先得了解JavaScript中的面向對象。因為這個操作符是檢測對象的原型鏈是否指向構造函數的prototype對象的。
實例:

3、使用 Object.prototype.toString 來判斷是否是數
Object.prototype.toString.call( [] ) === '[object Array]' // true
Object.prototype.toString.call( function(){} ) === '[object Function]' // true這里使用call來使 toString 中 this 指向 obj。進而完成判斷
4、使用 原型鏈 來完成判斷
[].__proto__ === Array.prototype // true
var fun = function(){}
fun.__proto__ === Function.prototype // true5、Array.isArray()
Array.isArray([]) // true
ECMAScript5將Array.isArray()正式引入JavaScript,目的就是準確地檢測一個值是否為數組。IE9+、 Firefox 4+、Safari 5+、Opera 10.5+和Chrome都實現了這個方法。但是在IE8之前的版本是不支持的。
以上就是js判斷一個對象是否是數組(函數)的方法的詳細內容了,看完之后是否有所收獲呢?如果如果想了解更多,歡迎來億速云行業資訊!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。