Array.prototype.every()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
every()
は Array
インスタンスのメソッドは、列内のすべての要素が指定された関数で実装されたテストに合格するかどうかをテストします。これは論理値を返します。
試してみましょう
構文
every(callbackFn)
every(callbackFn, thisArg)
引数
返値
callbackFn
関数がいずれかの要素で偽値を返した場合は、すぐに false
を返します。それ以外は true
です。
解説
every()
メソッドは反復処理メソッドです。配列のそれぞれの要素に対して、指定された callbackFn
関数が偽値を返すまで一度ずつ呼び出します。 そのような要素が見つかった場合、 every()
は直ちに false
を返し、配列の反復処理を中止します。そうでない場合、 callbackFn
がすべての要素に対して真値を返すと、 every()
は true
を返します。
every
は数学における「∀ (すべての / for all)」記号と同様のふるまいをします。特に、空の配列に対しては true
を返します。(空集合のすべての要素が与えられた任意の条件を満たすことは空虚に真です。)
callbackFn
は値が代入されている配列の要素に対してのみ呼び出されます。疎配列の空のスロットに対しては呼び出されません。
every()
は呼び出された配列を変更しませんが、 callbackFn
として指定された関数は変更することができます。ただし、配列の長さは callbackFn
を最初に呼び出す前に保存されることに注意してください。したがって、
callbackFn
は、every()
の呼び出しを始めたときの配列の長さを超えて追加された要素にはアクセスしません。- 既に処理したインデックスを変更しても、
callbackFn
が再度呼び出されることはありません。 - まだ処理していない既存の配列要素が
callbackFn
によって変更された場合、callbackFn
に渡される値はその要素が取得された時点での値になります。削除された要素は処理されません。
警告: 上記のように進行中の配列に対して変更を行うと、理解しにくいコードになることが多いので、(特別な場合を除いて)避けるのが一般的です。
every()
メソッドは汎用的です。このメソッドは this
の値に length
プロパティと整数のキーを持ったプロパティがあることだけを求めます。
例
すべての配列要素の大きさをテストする
次の例は、配列内のすべての要素が 10 以上であるかどうかテストします。
function isBigEnough(element, index, array) {
return element >= 10;
}
[12, 5, 8, 130, 44].every(isBigEnough); // false
[12, 54, 18, 130, 44].every(isBigEnough); // true
ある配列が別の配列の部分集合であるかどうかを調べる
以下の例では、ある配列のすべての要素が別の配列に存在するかどうかをテストしています。
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
疎配列に対する every() の使用
every()
は空のスロットに対して関数を実行しません。
console.log([1, , 3].every((x) => x !== undefined)); // true
console.log([2, , 2].every((x) => x === 2)); // true
初期配列への影響(変更、追加、削除)
次の例は、配列が変更されたときに every
メソッドの動作をテストするものです。
// ---------------
// アイテムの変更
// ---------------
let arr = [1, 2, 3, 4];
arr.every((elem, index, arr) => {
arr[index + 1]--;
console.log(`[${arr}][${index}] -> ${elem}`);
return elem < 2;
});
// ループは 3 回反復処理されるが、
// 何も変更しなければ 2 回実行される
//
// 1st iteration: [1,1,3,4][0] -> 1
// 2nd iteration: [1,1,2,4][1] -> 1
// 3rd iteration: [1,1,2,3][2] -> 2
// ---------------
// アイテムの追加
// ---------------
arr = [1, 2, 3];
arr.every((elem, index, arr) => {
arr.push("new");
console.log(`[${arr}][${index}] -> ${elem}`);
return elem < 4;
});
// 新しい項目を追加しても、ループは 3 回反復処理する
//
// 1st iteration: [1, 2, 3, new][0] -> 1
// 2nd iteration: [1, 2, 3, new, new][1] -> 2
// 3rd iteration: [1, 2, 3, new, new, new][2] -> 3
// ---------------
// アイテムの削除
// ---------------
arr = [1, 2, 3, 4];
arr.every((elem, index, arr) => {
arr.pop();
console.log(`[${arr}][${index}] -> ${elem}`);
return elem < 4;
});
// 残りのアイテムは `pop()` して取り除かれるため、ループは 2 回だけ反復処理される
//
// 1st iteration: [1,2,3][0] -> 1
// 2nd iteration: [1,2][1] -> 2
配列でないオブジェクトに対する every() の呼び出し
every()
メソッドは this
の length
プロパティを読み込み、すべてアクセスするか callbackFn
が false
を返すまで length
より小さい非負の整数キーを持つ各プロパティにアクセスします。
const arrayLike = {
length: 3,
0: "a",
1: "b",
2: "c",
3: 345, // length が 3 なので every() からは無視される
};
console.log(
Array.prototype.every.call(arrayLike, (x) => typeof x === "string"),
); // true
仕様書
Specification |
---|
ECMAScript Language Specification # sec-array.prototype.every |
ブラウザーの互換性
BCD tables only load in the browser