1. 程式人生 > 程式設計 >JavaScript 陣列遍歷的五種方法

JavaScript 陣列遍歷的五種方法

在使用 javascript 編寫程式碼過程中,可以使用多個方法對陣列進行遍歷;包括 for迴圈、forEach迴圈、map 迴圈、forIn迴圈和forOf迴圈等方法。

一、for 迴圈:基礎、簡單

這是最基礎和常用的遍歷陣列的方法;各種開發程式設計客棧語言一般都支援這種方法。

let arr = ['a'http://www.cppcns.com,'b','c','d','e'];
for (let i = 0,len = arr.length; i < len; i++) {
  console.log(i);    // 0 1 2 3 4
  console.log(arr[i]); //a b c d e
}

二、forEach() 方法:使用回撥函式

forEach() 這是陣列物件的一個方法;其接受一個回撥函式為引數。
回撥函式中有三個引數:

  • 1st:陣列元素(必選)
  • 2nd:陣列元素索引值(可選)
  • 3rd:陣列本身(可選)
let arr = ['a','e'];
arr.forEach((item,index,arr)=> {
  console.log(item);  // a b c d e 
  console.log(index); // 0 1 2 3 4
  console.log(arr);  // ['a','e']
})

三、map() 方法:使用回撥函式

其使用方式和 forEach() 方法相同。

var arr = [
  {name:'a',age:'18'},{name:'b',age:'19'},{name:'c',age:'20'}
];
arr.map(function(item,index) {
  if(item.name == 'b') {
    console.log(index) // 1
  }
})

四、for..in 迴圈:遍歷物件和陣列

for…in迴圈可用於迴圈物件和陣列。
推薦用於迴圈物件,也可以用來遍歷json。

let obj = {
  name: '王大錘',age: '18',weight: '
程式設計
客棧
70kg' } for(var key in obj) { console.log(key); // name age weight console.log(obj[key]); // 王大錘 18 70kg } ---------------------------- let arr = ['a','e']; for(var key in arr) { console.log(key); // 0 1 2 3 4 返回陣列索引 console.log(arr[key]) // a b c d e }

五、for…of 迴圈:遍歷物件和陣列

可迴圈陣列和物件,推薦用於遍歷陣列。

for…of提供了三個新方法:

  • key()是對鍵名的遍歷;
  • value()是對鍵值的遍歷;
  • entries()是對鍵值對的遍歷;
let arr = ['科大訊飛','政法BG',http://www.cppcns.com '前端開發'];
for (let item of arr) { 
 console.log(item); // 科大訊飛 政法BG 前端開發
}
// 輸出陣列索引
for (let item of arr.keys()) { 
 console.log(item); // 0 1 2
}
// 輸出內容和索引
for (let [item,val] of arr.entries()) { 
 console.log(item + ':' + val); // 0:科大訊飛 1:政法BG 2:前端開發
}

六、補充
程式設計客棧

6.1、break 和 Continue 問題

forEach、map、filter、reduce、every、some 函式中 break continue 關鍵詞都會不生效,因為是在function中,但function解決了閉包陷阱的問題。
要想使用 break、continue 可以使用 for、for...in、for...of、while

6.2、陣列和物件

用於遍歷陣列元素使用:for(),forEach(),map(),for...of
用於迴圈物件屬性使用:for...in

以上就是javaScript 陣列遍歷的五種方法的詳細內容,更多關於JavaScript 陣列遍歷的資料請關注我們其它相關文章!