溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

js中forEach怎么使用及forEach與for的區別是什么

發布時間:2022-03-29 17:46:41 來源:億速云 閱讀:232 作者:iii 欄目:開發技術

本篇內容介紹了“js中forEach怎么使用及forEach與for的區別是什么”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

一、定義和用法

forEach() 調用數組的每個元素,并將元素傳遞給回調函數。

  • 注意: forEach() 對于空數組是不會執行回調函數的。

用法:

array.forEach(function(currentValue, index, arr), thisValue)

1==> currentValue    必需。當前元素
2==> index    可選。當前元素的索引值,是數字類型的
3==> arr    可選。當前元素所屬的數組對象
4==> 可選。傳遞給函數的值一般用 "this" 值。
如果這個參數為空, "undefined" 會傳遞給 "this" 值

forEach 的注意點:

  • forEach() 本身是不支持的 continue break 語句的。

  • 我們可以通 return 語句實現 continue 關鍵字的效果

二、運用場景

1.運用的場景(計算數字之和)

計算數組所有元素相加的總和:

let arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
let sum = 0;
arr.forEach((currentIndex, index, curArr) => {
    sum += currentIndex
        // sum=sum+currentIndex
})
console.log('之和是', sum);

2.運用的場景(給原始數組新增key值)

//給原始數組的每一項新增一個屬性值
let arr = [{
  id: '001',
  name: '張三1'
}, {
  id: '002',
  name: '張三2'
}, {
  id: '003',
  name: '張三2'
}];
//給原始數組的每一項新增一個屬性值
arr.forEach((item, index) => {
  item['addAttrs'] = ''
})
console.log('arr', arr);

--使用for of來出處理--
for (let item of arr) {
    item['index'] = ''
}
console.log('arr', arr);

三、forEach 跳出循環

1.forEach 跳出當前的循環 return

//內容為3,不遍歷該項
var arr = [1, 2, 3];
arr.forEach(function(item) {
    if (item === 3) {
        return;
    }
    console.log(item);
});

2.forEach結合try跳出整個循環

  • 找到id為002,然后終止整個循環,返回當前這一項的值。

  • 使用try-catch完成的

代碼如下:

let arr = [{
  id: '001',
  name: '張三1'
}, {
  id: '002',
  name: '張三2'
}, {
  id: '003',
  name: '張三2'
}];

// 使用forEach跳出整個循環,使用rty-catch
function useForeach(Arr) {
  let obj = {}
  try {
    Arr.forEach(function(item) {
      if (item.id == '002') {
        // 找到目標項,賦值。然后拋出異常
        obj = item
        throw new Error('return false')
      }
    });
  } catch (e) {
    // 返回id===002的這一項的數據
    return obj
  }
}
console.log(useForeach(arr))

3.forEach 與for循環的區別 【面試題】

1==> for可以用continue跳過當前循環中的一個迭代,forEach 用continue會報錯。但是可以使用return來跳出當前的循環
2==> for可以使用break來跳出整個循環,forEach正常情況無法跳出整個循環。
如果面試官問:如果非要跳出forEach中的循環,可以拋出一個異常來處理

“js中forEach怎么使用及forEach與for的區別是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女