Generator.prototype.throw() - JavaScript 编辑
The throw()
method resumes the execution of a generator by throwing an error into it and returns an object with two properties done
and value
.
Syntax
gen.throw(exception)
Parameters
exception
- The exception to throw. For debugging purposes, it is useful to make it an
instanceof
Error
.
Return value
An Object
with two properties:
done
(boolean)- Has the value
true
if the iterator is past the end of the iterated sequence. In this casevalue
optionally specifies the return value of the iterator. - Has the value
false
if the iterator was able to produce the next value in the sequence. This is equivalent of not specifying thedone
property altogether.
- Has the value
value
- Any JavaScript value returned by the iterator. Can be omitted when
done
istrue
.
Examples
Using throw()
The following example shows a simple generator and an error that is thrown using the throw
method. An error can be caught by a try...catch
block as usual.
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 }
Specifications
Specification |
---|
ECMAScript (ECMA-262) The definition of 'Generator.prototype.throw' in that specification. |
Browser compatibility
BCD tables only load in the browser
See also
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论