Generator.prototype.throw()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2016.
throw()
メソッドは、ジェネレーターの例外を、エラーを発生させることで再開し、 done
と value
の 2 つのプロパティを持ったオブジェクトを返します。
構文
gen.throw(exception)
引数
返値
2 つのプロパティを持つ Object
です。
done
(boolean)-
- イテレーターが反復処理の末尾を過ぎている場合、値は
true
になります。この場合、value
はオプションでそのイテレーターの返値を指定します。 - イテレーターが反復処理の次の値を生成することができた場合、値は
false
になります。これはdone
プロパティを指定しない場合も同等です。
- イテレーターが反復処理の末尾を過ぎている場合、値は
value
-
イテレーターが返す何らかの JavaScript の値です。
done
がtrue
の場合は省略可能です。
例
throw() の使用
次の例では、簡単なジェネレーターと、 throw
メソッドを用いて発生させるエラーを示します。エラーは通常 try...catch
ブロックによって受け取られます。
js
function* gen() {
while (true) {
try {
yield 42;
} catch (e) {
console.log("Error caught!");
}
}
}
const g = gen();
g.next();
// { value: 42, done: false }
g.throw(new Error("Something went wrong"));
// "Error caught!"
// { value: 42, done: false }
仕様書
Specification |
---|
ECMAScript Language Specification # sec-generator.prototype.throw |
ブラウザーの互換性
BCD tables only load in the browser