首頁 > web前端 > js教程 > JavaScript中數組如何遍歷

JavaScript中數組如何遍歷

青灯夜游
發布: 2021-10-25 15:29:26
原創
25784 人瀏覽過

JavaScript中遍歷陣列的方法:1、使用for迴圈語句;2、使用forEach()方法呼叫回呼函數;3、使用map()方法呼叫回呼函數;4、使用「for..in 」迴圈語句;5、使用「for…of」迴圈語句。

JavaScript中數組如何遍歷

本教學操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

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

一、for 迴圈:基礎、簡單

#這是最基礎、常用的遍歷陣列的方法;各種開發語言一般都支援這種方法。

let arr = ['a','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 = [&#39;a&#39;,&#39;b&#39;,&#39;c&#39;,&#39;d&#39;,&#39;e&#39;];
arr.forEach((item,index,arr)=> {
  console.log(item);  // a b c d e 
  console.log(index); // 0 1 2 3 4
  console.log(arr);  // [&#39;a&#39;,&#39;b&#39;,&#39;c&#39;,&#39;d&#39;,&#39;e&#39;]
})
登入後複製

三、map() 方法:使用回呼函數

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

var arr = [
  {name:&#39;a&#39;,age:&#39;18&#39;},
  {name:&#39;b&#39;,age:&#39;19&#39;},
  {name:&#39;c&#39;,age:&#39;20&#39;}
];
arr.map(function(item,index) {
  if(item.name == &#39;b&#39;) {
    console.log(index) // 1
  }
})
登入後複製

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

for…in迴圈可用來循環物件和陣列。

推薦用於循環物件,也可以用來遍歷json。

let obj = {
  name: &#39;王大锤&#39;,
  age: &#39;18&#39;,
  weight: &#39;70kg&#39;
}
for(var key in obj) {
  console.log(key);    // name age weight
  console.log(obj[key]); // 王大锤 18 70kg
}
----------------------------
let arr = [&#39;a&#39;,&#39;b&#39;,&#39;c&#39;,&#39;d&#39;,&#39;e&#39;];
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 = [&#39;科大讯飞&#39;, &#39;政法BG&#39;, &#39;前端开发&#39;];
    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 + &#39;:&#39; + val); // 0:科大讯飞 1:政法BG 2:前端开发
    }
    登入後複製

    六、補充

    6.1、break 和Continue 問題

    forEach、map、filter、reduce、every、someforEach、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中數組如何遍歷的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板