美文网首页
async函数

async函数

作者: 牛耀 | 来源:发表于2018-09-26 23:04 被阅读0次

async函数(源自ES2017)
概念: 真正意义上去解决异步回调的问题,同步流程表达异步操作
本质: Generator的语法糖
语法:
async function foo(){
await 异步操作;
await 异步操作;
}
特点:
1、不需要像Generator去调用next方法,遇到await等待,当前的异步操作完成就往下执行
2、返回的总是Promise对象,可以用then方法进行下一步操作
3、async取代Generator函数的星号*,await取代Generator的yield
4、语意上更为明确,使用简单,经临床验证,暂时没有任何副作用

//async基本使用
    async function foo(){
        return new Promise(resolve => {
            // setTimeout(function(){
            //  resolve();
            // }, 2000);
            setTimeout(resolve, 2000);
        })
    }
    async function test(){
        console.log('开始执行', new Date().toTimeString());
        await foo();
        console.log('执行完毕', new Date().toTimeString());
    }
    // test();
    // async里await的返回值
    function test2(){
        return 'xxx';
    }
    async function asyncPrint(){
        // let result = await test2();
        let result = await Promise.resolve('promise');
        console.log(result);
        result = await Promise.reject('失败了~');
        console.log(result)
    }
    // asyncPrint();
    // 获取新闻内容
    async function getNews(url){
        return new Promise((resolve, reject) => {
            $.ajax({
                url,
                type: 'GET',
                dataType: 'json'
            })
            .done(data => resolve(data))
            // .fail(error => reject());
            .fail(error => resolve(false));
        });
    }
    async function sendXml(){
        let result = await getNews('http://localhost:3000/newsasdf?id=7');
        console.log(result);
        if(!result){
            alert('暂时没有新闻推送~~');
            return;
        }
        result = await getNews('http://localhost:3000' + result.commentsUrl);
        console.log(result);
        console.log('错误了~~');
    }
    sendXml();

相关文章

  • async和await的使用

    async函数 什么是async函数? async函数是使用async关键字声明的函数。 mdn文档:https:...

  • JS中的async/await -- 异步隧道尽头的亮光

    async函数 简单解释async函数就是Generator函数的语法糖。 Generator函数写法 async...

  • 2018-05-22

    async 函数 1. 含义 async 函数是 Generator 函数的语法糖。async函数将Generat...

  • ES8(13)、await 和 async 的用法

    async函数是使用async关键字声明的函数。 async函数是AsyncFunction构造函数的实例, 并且...

  • async函数

    async函数 async函数的含义 简单来说:async 函数就是 Generator 函数的语法糖下面是两个是...

  • ES8-async&await

    async函数是使用async关键字声明的函数,async函数是AsyncFunction构造函数的实例,返回值是...

  • async 函数(转载)

    async 函数 含义 ES2017 标准引入了 async 函数,使得异步操作变得更加方便。 async 函数是...

  • ES7 Async/Await快速入门

    用法: 使用async 声明函数,在async函数内使用await async function xxx(){aw...

  • ES6——异步操作

    async 函数 ES2017 标准引入了 async 函数,使得异步操作变得更加方便。async 函数是什么?一...

  • async/await 原理及简单实现

    解决函数回调经历了几个阶段, Promise 对象, Generator 函数到async函数。async函数目...

网友评论

      本文标题:async函数

      本文链接:https://www.haomeiwen.com/subject/euhsoftx.html