码迷,mamicode.com
首页 > Web开发 > 详细

js中控制流管理的三种方法

时间:2017-07-27 20:06:59      阅读:240      评论:0      收藏:0      [点我收藏+]

标签:running   ...   from   调用   adf   rom   opera   for   try   

引自http://es6.ruanyifeng.com/#docs/generator#yield--表达式

1.常用的回调方法

step1(function (value1) {
  step2(value1, function(value2) {
    step3(value2, function(value3) {
      step4(value3, function(value4) {
        // Do something with value4
      });
    });
  });
});

2.ES6中的Promise

Promise.resolve(step1)
  .then(step2)
  .then(step3)
  .then(step4)
  .then(function (value4) {
    // Do something with value4
  }, function (error) {
    // Handle any error from step1 through step4
  })
  .done();

3.Generator同步的方法

function* longRunningTask(value1) {
  try {
    var value2 = yield step1(value1);
    var value3 = yield step2(value2);
    var value4 = yield step3(value3);
    var value5 = yield step4(value4);
    // Do something with value4
  } catch (e) {
    // Handle any error from step1 through step4
  }

scheduler(longRunningTask(initialValue));

function scheduler(task) {
  var taskObj = task.next(task.value);
  // 如果Generator函数未结束,就继续调用
  if (!taskObj.done) {
    task.value = taskObj.value
    scheduler(task);
  }
}

另一种方法

let steps = [step1Func, step2Func, step3Func];

function *iterateSteps(steps){
  for (var i=0; i< steps.length; i++){
    var step = steps[i];
    yield step();
  }
}

4.Generator异步

function run(fn) {
  var gen = fn();

  function next(err, data) {
    var result = gen.next(data);
    if (result.done) return;
    result.value(next);
  }

  next();
}
var g = function* (){
  var f1 = yield readFile(‘fileA‘);
  var f2 = yield readFile(‘fileB‘);
  // ...
  var fn = yield readFile(‘fileN‘);
};

run(g);
 

 

js中控制流管理的三种方法

标签:running   ...   from   调用   adf   rom   opera   for   try   

原文地址:http://www.cnblogs.com/myzy/p/7246380.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!