Iterator.prototype.every()
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
every()
は Iterator
インスタンスのメソッドで、 Array.prototype.every()
と似ています。このイテレーターによって生成されたすべての要素が、指定された関数によって実装された試験に合格するかどうかを確認します。論理値を返します。
構文
every(callbackFn)
引数
callbackFn
-
このイテレーターによって生成された各要素に対して実行する関数。要素が試験に合格したことを示す真値、またはそうでなければ偽値を返さなければなりません。この関数は、以下の引数とともに呼び出されます。
返値
callbackFn
がすべての要素に対して真値を返した場合は true
です。そうでなければ false
です。
解説
every()
はイテレーターを反復処理し、各要素に対して一度ずつ callbackFn
関数を呼び出します。 コールバック関数が偽値を返した場合は、ただちに false
を返します。そうでない場合は、イテレーターの最後まで反復処理を行い、 true
を返します。 every()
が false
を返した場合、そのイテレーターの return()
メソッドを呼び出して終了します。
イテレーターヘルパーの主な利点は、配列メソッドよりも「遅延的」であるということです。つまり、要求されたときにのみ次の値を生成するという意味です。これにより、不必要なコンピューター処理を避けることができ、また無限イテレーターでも使用することができます。無限イテレーターでは、every()
は最初の偽値が得られるとすぐに false
を返します。もし callbackFn
が常に真値を返した場合、メソッドは終了しません。
例
every() の使用
function* fibonacci() {
let current = 1;
let next = 1;
while (true) {
yield current;
[current, next] = [next, current + next];
}
}
const isEven = (x) => x % 2 === 0;
console.log(fibonacci().every(isEven)); // false
const isPositive = (x) => x > 0;
console.log(fibonacci().take(10).every(isPositive)); // true
console.log(fibonacci().every(isPositive)); // Never completes
every()
を呼び出すと、メソッドが早期に終了した場合でも、常にその元となるイテレーターが閉じられます。 イテレーターが未完了の状態で残されることはありません。
const seq = fibonacci();
console.log(seq.every(isEven)); // false
console.log(seq.next()); // { value: undefined, done: true }
仕様書
Specification |
---|
Iterator Helpers # sec-iteratorprototype.every |
ブラウザーの互換性
BCD tables only load in the browser