JS陣列學習之判斷陣列元素是不是都滿足給定條件
那麼如何判斷陣列中元素是否滿足指定條件?例如遍歷陣列,檢查陣列中元素是否都為偶數,這要怎麼操作?
下面我們來介紹3種方法,先從熟悉的for迴圈開始,然後介紹2種內建函式--看看使用它們來怎麼檢測。
方法1:利用for迴圈
實現思想:
利用for語句來遍歷陣列
for(var i=0;i<a.length;i++){ }
檢查陣列中元素是否都為偶數,反過來:只要有一個不是偶數,那麼可以得出“不全為偶數”。
因此實現程式碼可以這麼寫:
var a = [2,4,5,6,8],b=0; for(var i=0;i<a.length;i++){ if (a[i] % 2 != 0) { b=0 break; }else{ b++; } } if (b) { console.log("都是偶數"); } else { console.log("不全為偶數"); }
分析程式碼:
我們使用了一箇中間變數
b
賦值為0,如果陣列元素為偶數,b就自增1;當有一個陣列元素不是偶數,b的值就又重新變為0,且使用“break;”退出迴圈。此時我們判斷變數b的值就能知道陣列中元素是否都為偶數:如果
b>0
則都是偶數;如果b=0
則不全為偶數。
因為陣列中元素5不是偶數,因此輸出結果為:
方法2:利用some()方法
some()方法可以檢測陣列中是否存在符合條件的元素。換個角度思考,也可以用來檢測陣列中的所有元素是否都不符合指定條件,都不符合的話就返回 false,有一個或者多個符合的話就返回 true。(和上文程式碼是一個思路)
array.some(function callbackfn(Value,index,array),thisValue)
function callbackfn(value,index,array)
:一個回撥函式,不可省略,最多可接受三個引數:
value:當前陣列元素的值,不可省略。
index:當前陣列元素的數字索引。
array:當前元素屬於的陣列物件。
我們來看看實現程式碼:
function f(value, index, ar) { if (value % 2 != 0) { return true; } } var a = [2,4,6,8,10,12]; var b = a.some(f); if (b) { console.log("不全為偶數"); } else { console.log("都是偶數"); }
可以看出:因為陣列中元素都是偶數,因此輸出結果為:
我們將陣列元素12改為11,則輸出結果為:
方法3:使用every()方法
every()方法可以檢測陣列元素是否全部符合指定條件。語法如下,引數取值情況可參考上文some() 方法
array.every(function callbackfn(Value,index,array),thisValue)
我們來看看實現程式碼:
function f(value, index, ar) { if (value % 2 == 0) { return true; }else { return false; } } var a = [2,4,6,8,10,11]; var b = a.every(f); if (b) { console.log("都是偶數"); } else { console.log("不全為偶數"); }
輸出結果為:
不全為偶數
every()和some() 方法的區別:
只有當陣列中的所有元素都滿足條件時,every() 才返回 true;只要陣列中有一個元素滿足條件,some() 就返回 true。
好了,就說到這裡了,有需要的可以看:
以上就是JS陣列學習之判斷陣列元素是不是都滿足給定條件的詳細內容,更多請關注php中文網其它相關文章!
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/2310/viewspace-2827354/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- js如何判斷陣列具有某個元素JS陣列
- js如何判斷陣列是否含有指定的元素JS陣列
- js:判斷物件或陣列JS物件陣列
- PHP陣列學習之計算陣列元素總和PHP陣列
- js如何判斷陣列中是否含有某個元素JS陣列
- JavaScript判斷陣列是否包含指定元素JavaScript陣列
- javascript如何判斷一個物件是不是陣列JavaScript物件陣列
- Array · 判斷某元素是否在陣列中陣列
- jquery判斷元素是否存在於陣列中jQuery陣列
- js資料型別判斷和陣列判斷JS資料型別陣列
- js判斷陣列中是否含有指定元素程式碼例項JS陣列
- jquery判斷指定元素是否存在於某陣列jQuery陣列
- js練習(一)找出元素item在給定陣列arr中的位置JS陣列
- JS型別判斷、物件克隆、陣列克隆JS型別物件陣列
- js判斷一個物件是否為陣列JS物件陣列
- 談談 js判斷陣列 那點事JS陣列
- 學習JSON陣列JSON陣列
- JavaScript 判斷是否是陣列JavaScript陣列
- Java學習之陣列Java陣列
- JS] JS 之刪除陣列中的元素JS陣列
- Laravel 條件陣列 in 的用法Laravel陣列
- 原生js 判斷變數是一個陣列JS變數陣列
- javascript陣列如何判斷是否有重複的陣列項JavaScript陣列
- js基礎-12-判斷陣列和判斷物件的方法JS陣列物件
- JS陣列學習筆記JS陣列筆記
- JavaScript判斷陣列還是物件JavaScript陣列物件
- 陣列學習陣列
- Java學習之陣列練習Java陣列
- js如何使用includes()判斷陣列是否含有指定值JS陣列
- js如何判斷一個引數是否是陣列JS陣列
- js查詢陣列元素位置JS陣列
- Go小工具系列——判斷元素是否存在於陣列中Go陣列
- C++列舉演算法之滿足條件的整數C++演算法
- iOS 判斷陣列array中是否包含指定的元素,取出該元素在array中的下標+陣列方法詳解...iOS陣列
- 判斷一個陣列是否排好序陣列
- 陣列元素逆序陣列
- JS陣列學習之清空全部元素的4種方法(程式碼詳解)JS陣列
- golang 陣列去重 移除陣列指定元素Golang陣列