JavaScript類數(shù)組對象轉(zhuǎn)換為數(shù)組對象的方法實例分析
本文實例分析了JavaScript類數(shù)組對象轉(zhuǎn)換為數(shù)組對象的方法。分享給大家供大家參考,具體如下:
1、類數(shù)組對象:
擁有length屬性,可以通過下標訪問;
不具有數(shù)組所具有的方法。
2、為什么要將類數(shù)組對象轉(zhuǎn)換為數(shù)組對象?
數(shù)組對象Array有很多方法:shift、unshift、splice、slice、concat、reverse、sort,ES6又新增了一些方法:forEach、isArray、indexOf、lastIndexOf、every、some、map、filter、reduce等。由于類數(shù)組不具有數(shù)組所具有的操作數(shù)組的方法,將類數(shù)組轉(zhuǎn)換為數(shù)組之后就能調(diào)用這些強大的方法,方便快捷。更多JavaScript數(shù)組的方法請見:http://www.dhdzp.com/article/144359.htm
3、類數(shù)組對象轉(zhuǎn)換為數(shù)組對象的方法:
1) Array.prototype.slice.call(arrayLike) 或 Array.prototype.slice.call(arrayLike, 0) 或 [].slice.call (arrayLike) 或 [].slice.call (arrayLike, 0)
var div1 = Array.prototype.slice.call(document.querySelectorAll('div'), 0);
var div2 = Array.prototype.slice.call(document.querySelectorAll('div'));
var div3 = [].prototype.slice.call(document.querySelectorAll('div'), 0);
var div4 = [].prototype.slice.call(document.querySelectorAll('div'));
2) Array.from(arrayLike)
var divs = Array.from(document.querySelectorAll('div'));
3) 原生JavaScript轉(zhuǎn)換
var length = arrayLike.length;
var arr = [];
for (var i = 0; i < length; i++) {
arr.push(arrayLike[i]);
return arr;
}
4、JavaScript如何判斷一個對象是否為數(shù)組?
使用typeof運算符不能判斷一個對象是否為數(shù)組,因為typeof arr返回的是object而不是array。
1) arr instanceof Array返回true
2) arr.constructor == Array返回true
說明:使用instanceof和constructor判斷數(shù)組類型的問題在于,它假定只有一個運行環(huán)境,如果網(wǎng)頁中包含多個框架,那么實際上存在兩個以上不同的全局執(zhí)行環(huán)境,進而存在兩個不同版本的Array構造函數(shù),如果從一個框架向另一個框架傳入一個數(shù)組,那么傳入的數(shù)組與第二個框架中原生創(chuàng)建的數(shù)組分別具有各自不同的構造函數(shù),也就是說,object.constructor == Array 會返回false。
原因:Array屬于引用型數(shù)據(jù),傳遞過程僅僅是引用地址的傳遞,每個頁面的Array原生對象所引用的地址是不一樣的,在子頁面聲明的Array所對應的構造函數(shù),是子頁面的Array對象,父頁面進行判斷時使用的Array并不等于子頁面的Array。
3) Array.isArray(arr)方法返回true
ES5新增了Array.isArray()方法,這個方法的目的是:最終確定一個值是否是數(shù)組,不管它是在哪個全局環(huán)境創(chuàng)建的。
4) Object.prototype.toString.call(arr) === "[object Array]"返回true
這是最簡單的判斷一個對象是否為數(shù)組的方法。
更多關于JavaScript相關內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)組操作技巧總結》、《JavaScript事件相關操作與技巧大全》、《JavaScript數(shù)據(jù)結構與算法技巧總結》、《JavaScript操作DOM技巧總結》及《JavaScript字符與字符串操作技巧總結》
希望本文所述對大家JavaScript程序設計有所幫助。
相關文章
jquery SweetAlert插件實現(xiàn)響應式提示框
為了滿足用戶體驗度,使用SweetAlert插件實現(xiàn)響應式提示框效果非常好,下面通過這篇文章給大家介紹jquery SweetAlert插件實現(xiàn)響應式提示框,需要的朋友可以參考下2015-08-08
JavaScript使用slice函數(shù)獲取數(shù)組部分元素的方法
這篇文章主要介紹了JavaScript使用slice函數(shù)獲取數(shù)組部分元素的方法,涉及javascript中slice方法的使用技巧,非常具有實用價值,需要的朋友可以參考下2015-04-04
JavaScript時間轉(zhuǎn)換處理函數(shù)
這篇文章主要介紹了JavaScript時間轉(zhuǎn)換處理函數(shù)的方法的相關資料,需要的朋友可以參考下2015-04-04

