日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
基于JS判斷對(duì)象是否是數(shù)組

這篇文章主要介紹了基于JS判斷對(duì)象是否是數(shù)組,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

創(chuàng)新互聯(lián)建站專注于中大型企業(yè)的成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)和網(wǎng)站改版、網(wǎng)站營(yíng)銷服務(wù),追求商業(yè)策劃與數(shù)據(jù)分析、創(chuàng)意藝術(shù)與技術(shù)開(kāi)發(fā)的融合,累計(jì)客戶千余家,服務(wù)滿意度達(dá)97%。幫助廣大客戶順利對(duì)接上互聯(lián)網(wǎng)浪潮,準(zhǔn)確優(yōu)選出符合自己需要的互聯(lián)網(wǎng)運(yùn)用,我們將一直專注成都品牌網(wǎng)站建設(shè)和互聯(lián)網(wǎng)程序開(kāi)發(fā),在前進(jìn)的路上,與客戶一起成長(zhǎng)!

1、通過(guò)instanceof判斷

instanceof運(yùn)算符用于檢驗(yàn)構(gòu)造函數(shù)的prototype屬性是否出現(xiàn)在對(duì)象的原型鏈中的任何位置,返回一個(gè)布爾值。

let a = [];
a instanceof Array; //true
let b = {};
b instanceof Array; //false

在上方代碼中,instanceof運(yùn)算符檢測(cè)Array.prototype屬性是否存在于變量a的原型鏈上,顯然a是一個(gè)數(shù)組,擁有Array.prototype屬性,所以為true。

需要注意的是,prototype屬性是可以修改的,所以并不是最初判斷為true就一定永遠(yuǎn)為真。

其次,當(dāng)我們的腳本擁有多個(gè)全局環(huán)境,例如html中擁有多個(gè)iframe對(duì)象,instanceof的驗(yàn)證結(jié)果可能不會(huì)符合預(yù)期,例如:

//為body創(chuàng)建并添加一個(gè)iframe對(duì)象
var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
//取得iframe對(duì)象的構(gòu)造數(shù)組方法
xArray = window.frames[0].Array;
//通過(guò)構(gòu)造函數(shù)獲取一個(gè)實(shí)例
var arr = new xArray(1,2,3); 
arr instanceof Array;//false

導(dǎo)致這種問(wèn)題是因?yàn)閕frame會(huì)產(chǎn)生新的全局環(huán)境,它也會(huì)擁有自己的Array.prototype屬性,讓不同環(huán)境下的屬性相同很明顯是不安全的做法,所以Array.prototype !== window.frames[0].Array.prototype,想要arr instanceof Array為true,你得保證arr是由原始Array構(gòu)造函數(shù)創(chuàng)建時(shí)才可行。

2、通過(guò)constructor判斷

我們知道,實(shí)例的構(gòu)造函數(shù)屬性constructor指向構(gòu)造函數(shù),那么通過(guò)constructor屬性也可以判斷是否為一個(gè)數(shù)組。

let a = [1,3,4];
a.constructor === Array;//true

同樣,這種判斷也會(huì)存在多個(gè)全局環(huán)境的問(wèn)題,導(dǎo)致的問(wèn)題與instanceof相同。

3、通過(guò)Object.prototype.toString.call()判斷

Object.prototype.toString().call()可以獲取到對(duì)象的不同類型,多個(gè)全局環(huán)境也適用

// 檢驗(yàn)是否是數(shù)組
 let a = [1,2,3]
 Object.prototype.toString.call(a) === '[object Array]';//true
 //檢驗(yàn)是否是函數(shù)
 let b = function () {};
 Object.prototype.toString.call(b) === '[object Function]';//true
 //檢驗(yàn)是否是數(shù)字
 let c = 1;
 Object.prototype.toString.call(c) === '[object Number]';//true

4、通過(guò)Array.isArray()判斷

簡(jiǎn)單好用,而且對(duì)于多全局環(huán)境,Array.isArray() 同樣能準(zhǔn)確判斷,但有個(gè)問(wèn)題,Array.isArray() 是在ES5中提出,也就是說(shuō)在ES5之前可能會(huì)存在不支持此方法的情況。

let a = [1,2,3]
Array.isArray(a);//true

最終推薦方法

if (!Array.isArray) {
 Array.isArray = function(arg) {
  return Object.prototype.toString.call(arg) === '[object Array]';
 };
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


新聞名稱:基于JS判斷對(duì)象是否是數(shù)組
文章網(wǎng)址:http://www.dlmjj.cn/article/jsohoh.html