JS function* 表达式

🌙
手机阅读
本文目录结构

function*关键字可以在表达式内部定义一个生成器函数。

function* foo() {
  yield 'a';
  yield 'b';
  yield 'c';
}

var str = "";
for (let val of foo()) {
  str = str + val;
}

console.log(str);
// expected output: "abc"

语法

function* [name]([param1[, param2[, ..., paramN]]]) {
   statements
}

参数

name

函数名。在声明匿名函数时可以省略。函数名称只是函数体中的一个本地变量。

paramN

传入函数的一个参数名。一个函数最多有 255 个参数。

statements

函数体。

描述

function表达式和 function 声明比较相似,并具有几乎相同的语法。function表达式和 function声明之间主要区别就是函数名,即在创建匿名函数时,function*表达式可以省略函数名。阅读函数章节了解更多信息。

示例

下面的示例定义了一个未命名的生成器函数并把它赋值给 x。函数产出它的传入参数的平方:

var x = function*(y) {
   yield y * y;
};

规范

Specification Status Comment
ECMAScript 2015 (6th Edition, ECMA-262)
function*
Standard Initial definition.
ECMAScript Latest Draft (ECMA-262)
function*
Draft

AXIHE / 精选资源

浏览全部教程

面试题

学习网站

前端培训
自己甄别

前端书籍

关于朱安邦

我叫 朱安邦,阿西河的站长,在杭州。

以前是一名平面设计师,后来开始接接触前端开发,主要研究前端技术中的JS方向。

业余时间我喜欢分享和交流自己的技术,欢迎大家关注我的 Bilibili

关注我: Github / 知乎

于2021年离开前端领域,目前重心放在研究区块链上面了

我叫朱安邦,阿西河的站长

目前在杭州从事区块链周边的开发工作,机械专业,以前从事平面设计工作。

2014年底脱产在老家自学6个月的前端技术,自学期间几乎从未出过家门,最终找到了满意的前端工作。更多>

于2021年离开前端领域,目前从事区块链方面工作了