JS和jQuery將類數組對象轉化成數組對象的幾種方法


1. Array.prototype.slice.call(arrayLike)

數組的slice()方法可以從已有數組中返回一個新數組,它接受兩個參數arr.slice(start,end),第一個參數規定從何處開始選取,第二個參數表示從何處選取結束(不包括),如果不傳參將返回原數組的一個副本,但該方法不會修改原數組,而是返回截取的新數組,根據這個就可以將類數組轉化成數組對象啦!

2. Array.prototype.splice.call(arrayLike,0)

splice(start,count,item)方法傳入的參數不同,第一個參數代表開始選取的元素位置,第二個說明選取的元素數量(不傳說明從第一個參數位置開始到數組的最后一個元素),第三個參數代表需要添加的元素(將會添加到第一個參數位置上)。

3. Array.from(array-like) ES6方法

4. 擴展運算符(...)ES6方法

1 //arguments對象
2 function foo(){
3   var args = [...arguments]
4 }
5 //NodeList對象
6 [...document.querySelectorAll('div')]

5. 循環遍歷類數組對象,push到新創建的數組對象里

1 var length = arrayLike.length;  
2 var arr = [];  
3 for (var i = 0; i < length; i++) {  
4     arr.push(arrayLike[i]);  
5     return arr;  
6 }  

6. jQuery方法:.get() .toArray()和$.makeArray(obj)

.get()
jQuery.map()通常用來處理一個簡單的數組或對象,由於返回值是一個jQuery包裹的數組,所以通常會使用get()方法將其轉換成普通的數組。例如:

 1   <p></p>
 2   <form>
 3     <input type="text" name="name" value="John"/>
 4  
 5     <input type="text" name="password" value="password"/>
 6     <input type="text" name="url" value="http://ejohn.org/"/>
 7  
 8   </form>
 9 <script>
10     $("p").append( $("input").map(function(){
11       return $(this).val();
12     }).get().join(", ") );       //John, password, http://ejohn.org/
13 </script>

.toArray()
$("div").toArray().reverse()

$.makeArray(obj)

1   var obj = $('li');
2   var arr = $.makeArray(obj);
3   jQuery.isArray(arr) //true;

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM