javascript – 为什么生成器方法构造函数?

前端之家收集整理的这篇文章主要介绍了javascript – 为什么生成器方法构造函数?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
声明为方法(使用ES6增强对象文字或类)的方法不是构造函数/没有原型链.

但是,当通过方法语法声明时,生成器有一个原型链,并且是构造函数.

采取以下示例 – (需要v8)

'use strict';
class x {
  *a() { this.b() }
  b() { print('class method'); }
}
let i = new x();
i.a.prototype.b = function() { print('generator method'); };
i.a().next();
(new i.a()).next();

输出,

class method
generator method

在将原型添加到i.b中,并调用新的i.b()将抛出一个错误,因为i.b不是构造函数,
我可以做新的i.a(),这里面的* a得到一个不同的上下文.

>为什么这种差异存在?
>将生成器中的原型定义为方法的用例是什么?

解决方法

绝对是ES2015规格的奇怪怪癖. TC39实际上有很长的讨论 back in July,决定到 make generators non-newable.

官方改变了规格landed last month,虽然有点担心破解的东西,V8和SpiderMonkey实现者赞成前进,所以我希望看到它停止工作很快(实际上,它已经抛出一个TypeError在Firefox中)

猜你在找的JavaScript相关文章