成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JavaScript中數組超級好用的方法

開發 前端
一說到JavaScript的數組,大家基本都能馬上想起pop()、push()、shift()、unshift()、indexof()等等,今天給大家分享幾個開發中常用的js數組方法。

一說到JavaScript的數組,大家基本都能馬上想起pop()、push()、shift()、unshift()、indexof()等等,今天給大家分享幾個開發中常用的JS數組方法。

[[425130]]

1、filter() 

  1. 語法:array.filter(function(currentValue,index,arr), thisValue) 
  2. 參數說明: 
  3. currentValue:當前元素對象(必選) 
  4. index:當前元素的索引值(可選) 
  5. arr:當前元素屬于的數組對象(可選) 
  6. thisValue:對象作為該執行回調時使用,傳遞給函數,用作 "this" 的值。 
  7. 如果省略了 thisValue ,"this" 的值為 "undefined"(可選) 

  

  1. //過濾年齡大于10的元素 
  2. var ages = [5, 32, 7, 10, 33, 12, 40]; 
  3. var res = ages.filter(function (currentValue) { 
  4.   return currentValue > 10; 
  5. }) 
  6. console.log(res.toString()); 
  7. //輸出結果:32,33,12,40 
  8.  
  9. //箭頭函數寫法 
  10. var res1 = ages.filter(item => item > 10) 
  11. console.log(res.toString()); 
  12. //輸出結果:32,33,12,40 

2、forEach() 

  1. 語法:array.forEach(function(currentValue, index, arr), thisValue) 
  2. 參數用法同上 

  

  1. //循環輸出每個參數 
  2. var ages = [5, 32, 7, 10, 33, 12, 40]; 
  3. ages.forEach(function (currentValue, index) { 
  4.   console.log("參數:" + currentValue + "索引:" + index); 
  5. }) 
  6.  
  7.  
  8. //箭頭函數寫法 
  9. ages.forEach((item, index) => { 
  10.   console.log("參數:" + item + "索引:" + index); 
  11. }) 

再看下面一段代碼: 

  1. //把10修改成20 
  2. var ages = [5, 32, 7, 10, 33, 12, 40]; 
  3. ages.forEach(function (currentValue, index) { 
  4.   if (currentValue === 10) { 
  5.     ages[index] = 20 
  6.     return 
  7.   } 
  8.   console.log(index); 
  9. }) 
  10.  
  11. console.log(ages); 

我們在代碼中將10的值改成20后,加了一個return,但是運行結果顯示還是打印了7次index的值,這就是forEach的一個缺點,只有循環結束才能停止。那如何解決呢?

3、some() 

  1. 語法:array.some(function(currentValue,index,arr),thisValue) 
  2. 參數用法同上 

  

  1. //把10修改成20 
  2. var ages = [5, 32, 7, 10, 33, 12, 40]; 
  3. ages.some(function (currentValue, index) { 
  4.   if (currentValue === 10) { 
  5.     ages[index] = 20 
  6.     return true 
  7.   } 
  8.   console.log(index); 
  9. }) 
  10.  
  11. console.log(ages); 
  12.  
  13. //把10修改成20 箭頭函數 
  14. var ages = [5, 32, 7, 10, 33, 12, 40]; 
  15. ages.some((item, index) => { 
  16.   if (item === 10) { 
  17.     ages[index] = 20 
  18.     return true 
  19.   } 
  20.   console.log(index); 
  21. }) 
  22.  
  23. console.log(ages); 

上面的代碼中運行結果只會打印三次index的值,通過some就可以完美解決forEach()的不足,開發過程中就看大家的需要就行選擇。

4、every() 

  1. 語法:array.every(function(currentValue,index,arr), thisValue) 
  2. 參數用法同上 

  

  1. //判斷每個元素的值是否都大于4 
  2. var ages = [5, 32, 7, 10, 33, 12, 40]; 
  3.  
  4.  
  5. var res = ages.some(function (currentValue) { 
  6.   return currentValue > 4 
  7. }) 

  8. console.log(res); 
  9. //輸出:true 
  10.  
  11. //箭頭函數 
  12. var res = ages.some(item => item > 4) 
  13. console.log(res); 

5、reduce() 

  1. 語法:array.reduce(function(total, currentValue, currentIndex, arr), initialValue) 
  2. 參數說明: 
  3. total:必需。初始值, 或者計算結束后的返回值。 
  4. currentValue:   必需。當前元素 
  5. currentIndex:可選。當前元素的索引 
  6. arr:可選。當前元素所屬的數組對象。 
  7. initialValue:可選。傳遞給函數的初始值 
  1. //計算所有元素的和 
  2. var numbers = [15.5, 2.3, 1.1, 4.7]; 
  3. var res = numbers.reduce(function (total, currentValue) { 
  4.   return total += currentValue 
  5. }, 0) 
  6.  
  7. console.log(res); 
  8. //23.6 
  9.  
  10. //計算大于4的元素的和 
  11. var result = numbers.filter(item => item > 4).reduce((total, item) => total += item, 0) 
  12. console.log(result); 
  13. //20.2 

6、合并數組 

  1. 用法:var arr = [...數組1,...數組2] 
  2. 結果:將數組2的元素值拼接到數組1元素值后面 

 

  1. var arr = [1, 2, 3] 
  2. var arr2 = [4, 5, 6] 
  3.  
  4. var res = [...arr, ...arr2] 
  5. console.log(res); 
  6. //輸出結果:[1, 2, 3, 4, 5, 6] 
  7.  
  8. var res = [...arr2, ...arr] 
  9. console.log(res); 
  10. //輸出結果: [4, 5, 6, 1, 2, 3] 

 【編輯推薦】

 

責任編輯:華軒 來源: 今日頭條
相關推薦

2023-08-18 15:12:00

JavaScript開發

2016-10-13 19:33:10

javascript數組indexOf

2016-12-27 10:19:42

JavaScriptindexOf

2015-07-16 14:51:13

下載助手斷點續傳多任務

2013-05-27 15:07:36

Eclipse插件

2020-06-24 07:44:12

Python數據技術

2024-07-26 00:35:33

2024-03-21 14:27:13

JavaScript數組

2021-08-27 13:20:06

PythonAddict模塊

2022-11-13 15:33:30

JavaScript數組開發

2025-02-10 07:00:00

JavaScript數組方法前端

2022-10-26 10:15:53

GoFramePHP數組

2021-04-26 07:51:00

JavaScript方法函數

2021-02-07 22:59:55

JavaScript編程方法鏈

2023-06-28 00:02:40

2023-07-18 07:56:31

工具reduce業務

2023-07-04 15:52:49

JavaScript數組

2020-06-30 10:37:55

JavaScript開發技術

2023-02-01 08:31:48

2021-03-12 14:52:18

插件VS Code工具
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产高清一二三区 | 最新中文字幕在线播放 | 免费99视频 | 久草视频在线播放 | 久久精品毛片 | 久久午夜剧场 | avtt国产| 久久精品av麻豆的观看方式 | 国产美女久久久 | 亚洲第一福利网 | 超碰国产在线 | 精品日韩一区二区三区av动图 | 黄色欧美在线 | 精品视频国产 | 日日碰碰 | 一本综合久久 | 中文久久 | 91免费看片神器 | 日韩免费在线视频 | 国产极品粉嫩美女呻吟在线看人 | 99九色| 九九看片 | 精品欧美乱码久久久久久1区2区 | 精品乱码一区二区三四区 | 伊人超碰 | 51ⅴ精品国产91久久久久久 | 亚洲第一福利网 | 久久久久黄色 | 亚洲精品一区二区三区丝袜 | 午夜男人免费视频 | 91在线影院 | 欧亚av在线| 福利视频一区二区三区 | 国产91 在线播放 | 一级毛片免费视频 | 97色在线观看免费视频 | 亚洲网址在线观看 | 国产一区二区在线免费播放 | 亚洲国产一区二区三区在线观看 | 中文字幕精品一区 | 中文字幕日韩欧美一区二区三区 |