ES6-Generator(生成器)

ES6定义generator标准是借鉴了Python的generator的概念和语法。
一个generator看上去像一个函数,但可以返回多次。

Generator函数使用方法

  1. function和函数名之间有一个*号
  2. 函数体内部使用了yield表达式,例如:
function* gen(x) {
	yield x+1;
	yield x+2;
	return x+3;
}
  1. 单纯运行generator函数后,只会返回一个generator对象并没有执行它。
    调用generator对象有两个方法:
  • 不断的调用generator对象的next()方法:
var f = gen(5);
f.next();		//{value: 6, done: false}
f.next();		//{value: 7, done: false}
f.next();		//{value: 8, done: true}

next()方法会执行generator的代码,然后,每次遇到yield,就会返回一个对象{value: x, done: true/false},然后暂停。
返回的value就是yield的返回值,done表示这个generator是否已经执行结束了。如果done为true,则value就是return的返回值。

  • 另一个方法就是直接调用for … of循环迭代generator对象,这种方法不需要自己判断done。
'use strict'

function* fib(max) {
    var
        t,
        a = 0,
        b = 1,
        n = 0;
    while (n < max) {
        yield a;
        [a, b] = [b, a + b];
        n ++;
    }
    return;
}

for (var x of fib(10)) {
console.log(x); // 依次输出0, 1, 1, 2, 3, …
}

yield*

yield* 这种语句让我们可以在Generator函数里面再套一个Generator, 当然你要在一个Generator里面调用另外的Generator需要使用: yield* 函数;这种语法

function* foo() {
    yield 0;
    yield 1;
}
function* bar() {
    yield 'x';
    yield* foo();
    yield 'y';
}
for (let v of bar()){
    console.log(v);
};

实际使用

   ajax的异步处理, 利用生成器的特性,不但可以用于ajax的异步处理, 也能够用于浏览器的文件系统filesystem的异步:

<html>
<head>
    <meta charset="utf-8">
    <script src="//cdn.bootcss.com/jquery/3.0.0-beta1/jquery.min.js"></script>
</head>
<body>
    <script>
        "use strict";
        function* main() {
            var result = yield request("http://www.filltext.com?rows=10&f={firstName}");
            console.log(result);
            //do 别的ajax请求;
        }

        function request(url) {
            var r = new XMLHttpRequest();
            r.open("GET", url, true);
            r.onreadystatechange = function () {
                if (r.readyState != 4 || r.status != 200) return;
                var data = JSON.parse(r.responseText);
                //数据成功返回以后, 代码就能够继续往下走了;
                it.next(data);
            };
            r.send();
        }

        var it = main();
        it.next();
        console.log("执行到这儿啦");
    </script>
</body>
</html>

   以上代码中的console.log(“执行到这儿啦”);先被执行了, 然后才出现了ajax的返回结果, 也就说明了Generator函数是异步的了;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: @babel/plugin-transform-async-to-generator是一个Babel插件,它将async/await语法转换为ES5代码,以便在不支持该语法的环境中运行。要配置该插件,请按照以下步骤操作: 1. 安装@babel/plugin-transform-async-to-generator插件: ``` npm install --save-dev @babel/plugin-transform-async-to-generator ``` 2. 在babel配置文件中添加该插件: ```javascript { "plugins": ["@babel/plugin-transform-async-to-generator"] } ``` 3. 如果您使用的是babel 7及以上版本,可以将插件配置为使用"options"选项: ```javascript { "plugins": [ ["@babel/plugin-transform-async-to-generator", { "module": "bluebird", "method": "coroutine" }] ] } ``` 这里的例子展示了如何使用bluebird库中的coroutine方法来提供async/await功能。您可以使用其他库或方法来实现相同的效果。 注意:如果您使用的是babel 6.x版本,则需要在插件名称前添加"babel-"前缀,例如"babel-plugin-transform-async-to-generator"。 ### 回答2: @babel/plugin-transform-async-to-generator是一个Babel插件,用于将ES7中的`async/await`转换为ES6中的生成器函数。要配置该插件,您需要按照以下步骤进行操作: 1. 首先,安装插件,通过运行以下命令:`npm install --save-dev @babel/plugin-transform-async-to-generator`。 2. 在项目的根目录下创建一个名为`.babelrc`的文件(如果它不存在)。这是Babel的配置文件。 3. 在`.babelrc`文件中,添加以下内容: ```json { "plugins": ["@babel/plugin-transform-async-to-generator"] } ``` 这指示Babel加载并使用@babel/plugin-transform-async-to-generator插件。 4. 如果您使用的是Babel 7以上的版本,可以在`.babelrc`中指定插件的参数。例如,要指定`regenerator`作为插件的参数(用于支持较旧的浏览器),您的`.babelrc`文件应如下所示: ```json { "plugins": [ ["@babel/plugin-transform-async-to-generator", { "regenerator": true }] ] } ``` 这样配置后,Babel将在转换代码时使用@babel/plugin-transform-async-to-generator插件,并根据需要设置生成器函数的参数。 请注意,配置文件`.babelrc`的路径可以根据您的项目结构和工具链的不同而有所不同。记得根据您的实际情况,根据需要设置正确的路径。 希望这能帮到您!如果您有其他问题,请随时提问。 ### 回答3: @babel/plugin-transform-async-to-generator是一个可以将async/await语法转换成generator函数的Babel插件。要配置该插件,你需要按照以下步骤进行操作: 第一步,安装插件: ``` npm install --save-dev @babel/plugin-transform-async-to-generator ``` 第二步,在你的babel配置文件(如.babelrc)中添加插件的相关配置: ```json { "plugins": ["@babel/plugin-transform-async-to-generator"] } ``` 或者,如果你使用的是babel.config.js,可以按照以下方式进行配置: ```javascript module.exports = { plugins: ['@babel/plugin-transform-async-to-generator'] } ``` 完成以上配置后,插件会自动转换你的async/await语法成generator函数,使之能够在不支持async/await的环境中运行。 注意,插件的配置选项是可选的,你可以根据需要进行进一步配置。你可以在插件配置中指定一个"module"选项,该选项用于控制生成的模块类型,可选的值为"commonjs"和"amd"。默认值为"commonjs"。 希望以上回答能够帮助到你!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值