The every()
method of Array
instances tests whether all elements in the array pass the test implemented by the provided function. It returns a Boolean value.
The every()
method of Array
instances tests whether all elements in the array pass the test implemented by the provided function. It returns a Boolean value.
every(callbackFn) every(callbackFn, thisArg)
callbackFn
A function to execute for each element in the array. It should return a truthy value to indicate the element passes the test, and a falsy value otherwise. The function is called with the following arguments:
thisArg
Optional
A value to use as this
when executing callbackFn
. See iterative methods.
true
unless callbackFn
returns a falsy value for an array element, in which case false
is immediately returned.
The every()
method is an iterative method. It calls a provided callbackFn
function once for each element in an array, until the callbackFn
returns a falsy value. If such an element is found, every()
immediately returns false
and stops iterating through the array. Otherwise, if callbackFn
returns a truthy value for all elements, every()
returns true
. Read the iterative methods section for more information about how these methods work in general.
every
acts like the "for all" quantifier in mathematics. In particular, for an empty array, it returns true
. (It is vacuously true that all elements of the empty set satisfy any given condition.)
callbackFn
is invoked only for array indexes which have assigned values. It is not invoked for empty slots in sparse arrays.
The every()
method is generic. It only expects the this
value to have a length
property and integer-keyed properties.
The following example tests whether all elements in the array are 10 or bigger.
function isBigEnough(element, index, array) { return element >= 10; } [12, 5, 8, 130, 44].every(isBigEnough); // false [12, 54, 18, 130, 44].every(isBigEnough); // true
The following example tests if all the elements of an array are present in another array.
const isSubset = (array1, array2) => array2.every((element) => array1.includes(element)); console.log(isSubset([1, 2, 3, 4, 5, 6, 7], [5, 7, 6])); // true console.log(isSubset([1, 2, 3, 4, 5, 6, 7], [5, 8, 7])); // false
The array
argument is useful if you want to access another element in the array. The following example first uses filter()
to extract the positive values and then uses every()
to check whether the array is strictly increasing.
const numbers = [-2, 4, -8, 16, -32]; const isIncreasing = numbers .filter((num) => num > 0) .every((num, idx, arr) => { // Without the arr argument, there's no way to easily access the // intermediate array without saving it to a variable. if (idx === 0) return true; return num > arr[idx - 1]; }); console.log(isIncreasing); // true
every()
will not run its predicate on empty slots.
console.log([1, , 3].every((x) => x !== undefined)); // true console.log([2, , 2].every((x) => x === 2)); // true
The every()
method reads the length
property of this
and then accesses each property with a nonnegative integer key less than length
until they all have been accessed or callbackFn
returns false
.
const arrayLike = { length: 3, 0: "a", 1: "b", 2: "c", 3: 345, // ignored by every() since length is 3 }; console.log( Array.prototype.every.call(arrayLike, (x) => typeof x === "string"), ); // true
Desktop | Mobile | Server | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | Deno | Node.js | ||
every |
1 | 12 | 1.5 | 9.5 | 3 | 18 | 4 | 10.1 | 1 | 1.0 | ≤37 | 1.0 | 0.10.0 |
© 2005–2023 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/every