作家
登录

用Async函数简化异步代码

作者: 来源: 2017-04-19 11:20:13 阅读 我要评论

  •   return asynchronousOperation() 
  •  
  •     .then(function(val) { 
  •  
  •       return asynchronousOperation(val); 
  •  
  •     }) 
  •  
  •     .then(function(val) { 
  •  
  •       return asynchronousOperation(val); 
  •  
  •     }) 
  •  
  •     .then(function(val) { 
  •  
  •       return asynchronousOperation(val); 
  •  
  •     }); 
  •  
  •  
  • 应用 async 函数,只须要像编写同步代码那样调用 asynchronousOperation:

    1. async function doAsyncOp () { 
    2.  
    3.   var val = await asynchronousOperation(); 
    4.  
    5.   val = await asynchronousOperation(val); 
    6.  
    7.   val = await asynchronousOperation(val); 
    8.  
    9.   return await asynchronousOperation(val); 
    10.  
    11. };  
    1. function getAllFiles(fileNames) { 
    2.  
    3.   return Promise.all
    4.  
    5.     fileNames.map(function(fileName) { 
    6.  
    7.       return getFileAsync(fileName).then(function(file) { 
    8.  
    9.         return parse(file); 
    10.  
    11.       }); 
    12.  
    13.     }) 
    14.  
    15.   ); 
    16.  
    17.  

    甚至最后的 return 语句中都不须要应用 await,因为用或不消,它都返回了包含了可处理终值的 Promise。

    Promise 还有另一个巨大年夜的特点,它们可以同时进行多个异步操作,等他们全部完成之后再持续进行其它事宜。ES2015 规范中供给了 Promise.all(),就是用来干这个工作的。

    1. function doAsyncOp() { 
    2.  
    3.   return Promise.all([ 
    4.  
    5.     asynchronousOperation(), 
    6.  
    7.     asynchronousOperation() 
    8.  
    9.   ]).then(function

        推荐阅读

        一文看懂数据可视化:从编程工具到可视化表现方式

      说到可视化,就不得不说一下大年夜数据,毕竟可视化是解决大年夜数据的一种高效的手段,而如今人人都在谈论大年夜数据,大年夜数据 ≠ 稀有据 ≠ 数据量大年夜, 离谱的是,如今就连>>>详细阅读


      本文标题:用Async函数简化异步代码

      地址:http://www.17bianji.com/lsqh/34848.html

    关键词: 探索发现

    乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

    网友点评
    自媒体专栏

    评论

    热度

    精彩导读
    栏目ID=71的表不存在(操作类型=0)