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 2016年9月.
throw() は Generator インスタンスのメソッドで、ジェネレーターの本体内で、現在の停止位置に throw 文が挿入されたかのように振る舞い、ジェネレーターがエラー状態にあることを知らせ、エラーを処理したり、クリーンアップ処理を行って自分自身を閉じたりすることができるようにします。
構文
generatorInstance.throw(exception)
引数
返値
2 つのプロパティを持つ Object です。
例外
TypeError-
ジェネレーターが既に実行中である場合に発生します。
exception がジェネレーター関数内の try...catch で捕捉されなかった場合、throw() の呼び出し側にも例外が送出されます。
解説
throw() メソッドが呼び出されると、ジェネレーターの本体内で現在中断されている位置に throw exception; 文が挿入されたかのように見なされます。ここで exception は throw() メソッドに渡された例外です。したがって、通常のフローでは、throw(exception) を呼び出すとジェネレーターが例外を発生します。ただし、yield 式が try...catch ブロックで囲まれている場合、エラーが補足され、エラー処理後に制御フローを再開するか、正常に終了させることが可能です。
例
>throw() の使用
次の例では、簡単なジェネレーターと、 throw メソッドを用いて発生させるエラーを示します。エラーは通常 try...catch ブロックによって受け取られます。
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® 2026 Language Specification> # sec-generator.prototype.throw> |