Generator(生成器)
序言
generator(生成器)是ES6引入的一种新的标准,可以用于处理异步请求,将异步回调的方式已同步的方式展示。generator和函数不同的是,generator由function*定义(注意多出的*号),并且,除了return语句,还可以用yield返回多次。
关于Generator的斐波那契数列
function fit(max) { var a=0, b=1, arr=[0,1]; while( arr.length < max ){ [a,b]=[b,a+b]; arr.push(b); } return arr; }
当我们调用fit时,会将所有的结果输出,如果我们想要了解斐波那契数列产生的每一步结果呢?那就需要我们使用generator。
function* fib(max) { var t, a = 0, b = 1, n = 0; while (n < max) { yield a; [a, b] = [b, a + b]; n ++; } return; }
Generator在AJAX中的运用
原始的AJAX异步请求需要我们去层层嵌套
ajax('http://...', data1, function (err, result) { if (err) { return handle(err); } ajax('http://...', data2, function (err, result) { if (err) { return handle(err); } ajax('http://...', data3, function (err, result) { if (err) { return handle(err); } return success(result); }); }); });
当我们使用Generator去处理AJAX请求时,我们的语法变得多么优雅,简洁:
try { r1 = yield ajax('http://...', data1); r2 = yield ajax('http://...', data2); r3 = yield ajax('http://...', data3); success(r3); } catch (err) { handle(err); }
Generator在闭包中的运用
闭包实现方式全局变量current_id 保存记数.
var current_id = 0; function next_id() { current_id ++; return current_id; } generator实现计数功能: function* next_id(){ var time=0; while(true){ time+=1; yield time; }