2.9JavaScript引用类型之生成器(Generator)

Generator 类型实现了 Iterable 接口。

1.生成器函数声明

生成器函数声明只需要在函数名前面加一个星号 * 即可,星号 * 不受两侧空格的影响。

生成器函数支持函数声明、函数表达式,不支持箭头函数表达式。

//生成器函数声明
[async] function* 生成器函数名() {}
[async] function *生成器函数名() {}
[async] function * 生成器函数名() {}
//生成器函数表达式
//命名生成器函数表达式
{ let | const } gf = [async] function *生成器函数名() {};

//匿名生成器函数表达式
{ let | const } gf = [async] function* () {};

2.yield和yield *

yield 关键字用来多次暂停和恢复一个生成器函数,它可以被认为是一个基于生成器函数版本的 return 关键字。

注意:同一个生成器函数内部可以同时出现 yieldreturn

function *生成器函数名() {
  yield [表达式];
}

yield * 表达式用于委托给另一个生成器 或 可迭代对象。

与生成器函数定义类似,yield 关键字后的星号 * 不受两侧空格的影响。

function *name() {
    yield* 表达式;
    yield *表达式;
    yield * 表达式;
}

3.生成器函数作用域

3.1全局函数

名称修饰符
全局函数参考生成器函数声明、生成器函数表达式。

3.2成员方法

名称修饰符
静态访问器属性(类)static get *static set *
静态方法(类)static *
静态初始化块(类)static *
实例访问器属性(类)get *set *
实例方法(类)*
构造函数(类)*
访问器属性(对象字面量)get *set *
方法(对象字面量)*

3.3局部函数

名称修饰符
嵌套函数参考生成器函数声明、生成器函数表达式。

4.生成器函数调用

生成器函数调用会返回一个Generator 类型的实例,与迭代器相似,Generator 也实现了 Iterator 接口。

原创文章,作者:huoxiaoqiang,如若转载,请注明出处:https://www.huoxiaoqiang.com/javascript/javascriptlang/20615.html

(0)
huoxiaoqiang的头像huoxiaoqiang
上一篇 2020年9月8日 12:15
下一篇 2020年9月10日 16:32

相关推荐

  • 1.6JavaScript语言的常量(Constant)

    1.常量声明 注意:在同一个作用域,相同名称的常量不可以重复声明,否则会报错。 常量在赋值后不可以通过重新赋值改变其值,即使新的值与老的值相同也不可以。 如果一个常量存储的是对象的引用,意味着此常量总是引用同一个对象,但是,改变对象的属性的值是可以的。 注意:属性新的值的类型不一定与属性老的值的类型相同。 2.常量声明…

  • 1.7JavaScript语言的函数(Function)

    1.Function()函数方式 Function() 函数方式创建的函数定义存在安全性和性能问题,所以不推荐使用,不过此种创建函数定义的方式很好地诠释了函数声明、函数表达式、箭头函数表达式是 Function 类型的实例这个概念。 2.函数声明 注意:在同一个作用域,相同名称的函数可以重复声明,但后定义的会覆盖先定义…

  • 3.TypeScript常用语法一览表

    1.JSDoc注释 2.非运算符 非运算符 描述 标识符? 用于函数的形参名、对象类型的属性名后面,表示是可选的(可传递实参,也可不传递实参,当不传递实参的时候,相当于传递了 undefined 值)。 3.类型 3.1常用类型 类型 描述 bigint 大整数类型 number 数值类型 boolean 布尔类型 s…

发表回复

登录后才能评论