--- title: Generator.prototype.throw() slug: Web/JavaScript/Reference/Global_Objects/Generator/throw tags: - ECMAScript6 - JavaScript - 参考 - 属性 - 方法 - 生成器 translation_of: Web/JavaScript/Reference/Global_Objects/Generator/throw ---
{{JSRef}}

throw() 方法用来向生成器抛出异常,并恢复生成器的执行,返回带有 donevalue 两个属性的对象。

语法

gen.throw(exception)

参数

exception
用于抛出的异常。 使用 {{jsxref("Error")}} 的实例对调试非常有帮助.

返回值

带有两个属性的{{jsxref("Object", "对象")}}:

示例

使用 throw()

下面的例子展示了一个简单的生成器并使用 throw方法向该生成器抛出一个异常,该异常通常可以通过 try...catch 块进行捕获.

function* gen() {
  while(true) {
    try {
       yield 42;
    } catch(e) {
      console.log("Error caught!");
    }
  }
}

var g = gen();
g.next(); // { value: 42, done: false }
g.throw(new Error("Something went wrong")); // "Error caught!"

规范

Specification Status Comment
{{SpecName('ES6', '#sec-generator.prototype.throw', 'Generator.prototype.throw')}} {{Spec2('ES6')}} Initial definition.
{{SpecName('ESDraft', '#sec-generator.prototype.throw', 'Generator.prototype.throw')}} {{Spec2('ESDraft')}}  

浏览器兼容性

{{Compat}}

相关链接