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日
下一篇 2020年9月10日

相关推荐

  • 2.5JavaScript引用类型之数组(Array)

    数组是一种特殊的对象。 1.索引数组 注意:最后一个元素后面允许有逗号 ,,这样要添加一个新元素时很方便。 2.稀疏(Sparse)数组 从上面的示例中,我们不难发现,空槽(empty slot)占用数组的长度,但是数组不存在空槽这个元素,换句话说,对象不存在空槽这个属性。 所以像这种数组长度大于数组实际的元素个数的数…

  • 2.2JavaScript原始类型之字符串(String)

    1.单引号和双引号字符串字面量 JavaScript 语言的单引号和双引号字符串字面量语法上没有区别,所以以下一并讲解。 单引号和双引号字符串字面量支持所有转义序列。 单引号和双引号字符串字面量不支持字符串插值。 单引号和双引号字符串字面量支持在每行末尾添加一个转义字符反斜杠 \ 转义隐式的换行符从而跨多行编写一行代码…

  • 2.3JavaScript原始类型之符号(Symbol)

    一个符号实例用于表示一个唯一的标识符。 1.创建符号实例 注意:符号实例不支持字面量创建方式。 注意:符号实例不支持 new Symbol() 创建方式。 Symbol() 函数可选地接受一个字符串实参,字符串实参仅仅作为对符号实例的描述,将来可以通过这个字符串实参来调试代码,不影响任何事情。 Symbol() 函数的…

发表回复

登录后才能评论