JavaScript generator-生成器

with廖老师前端记录
https://www.liaoxuefeng.com/wiki/1022910821149312/1023024381818112

generator

  • generator(生成器)是ES6标准引入的新的数据类型。一个generator看上去像一个函数,但可以返回多次。
定义
  • generator和函数不同的是,generator由function*定义(注意多出的*号),
  • 除了return语句,还可以用yield返回多次。
function* foo(x) {
    yield x + 1;
    yield x + 2;
    return x + 3;
}

var gen = foo(10);
gen.next().value;	 // 11
gen.next();	 			 // {value: 12, done: false}
gen.next();	 			 // {value: 13, done: true}
gen.next();	 			 // {value: undefined, done: true}
  • 直接调用一个generator和调用函数不一样,gen(10)仅仅是创建了一个generator对象,还没有去执行它
next

调用generator对象有两个方法,一是不断地调用generator对象的next()方法

  • 每次遇到yield x;就返回一个对象{value: x, done: true/false},然后“暂停”。

  • 返回的value就是yield的返回值,done表示这个generator是否已经执行结束了。

  • 如果donetrue,则value就是return的返回值。

第二个方法是直接用for ... of循环迭代generator对象,这种方式不需要自己判断done

  • 不包含return:return;一般为
for (var x of gen(10)) {
    console.log(x); // 依次输出11,12
}
解决回调地狱

generator还有另一个巨大的好处,就是把异步回调代码变成“同步”代码。

ajax参数回调

ajax('http://url-1', data1, function (err, result) {
    if (err) {
        return handle(err);
    }
    ajax('http://url-2', data2, function (err, result) {
        if (err) {
            return handle(err);
        }
        return success(result);
    });
});


// 有了generator的美好时代,用AJAX时可以这么写:
try {
    r1 = yield ajax('http://url-1', data1);
    r2 = yield ajax('http://url-2', data2);
    r3 = yield ajax('http://url-3', data3);
    success(r3);
}
catch (err) {
    handle(err);
}

看上去是同步的代码,实际执行是异步的。

因为generator可以在执行过程中多次返回,所以它看上去就像一个可以记住执行状态的函数

自增ID

// 要生成一个自增的ID,可以编写一个next_id()函数(每次保存状态):
function* nextId() {
    var id = 0;
    while(true) {
      // yield可以用来加强控制,懒汉式加载
       yield ++id;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值