promise异步请求串行异步then并行异步all竞争异步race 传递参数resolve(then)reject(catch)

1.印象

古人云:“君子一诺千金”,这种“承诺将来会执行”的对象在JavaScript中称为Promise对象。

Promise就是解决多个异步请求的问题

Promise有三种状态:Pending(进行中)、Resolved(已完成)和 Rejected(已失败)

串行异步then并行异步all竞争异步race 传递参数resolve(then)reject(catch)

2.案例

使用promise执行异步函数我们可以在promise里定义异步函数 ,then与catch分别捕获resolve与reject抛出的信息

new Promise(function (resolve, reject) {
    console.log('start new Promise...');
    var timeOut = 0.5;
    console.log('set timeout to: ' + timeOut + ' seconds.');
    setTimeout(function () {
        if (timeOut < 1) {
            console.log('call resolve()...');
            resolve('200 OK INFO');
        }
        else {
            console.log('call reject()...');
            reject('timeout in ' + timeOut + ' seconds.');
        }
    }, timeOut * 1000);
}).then(function (r) {
    console.log('Done: ' + r);
}).catch(function (reason) {
    console.log('Failed: ' + reason);
});


VM353:2 start new Promise...
VM353:4 set timeout to: 0.5 seconds.
Promise {<pending>}
VM353:7 call resolve()...
VM353:16 Done: 200 OK INFO

setTimeout(function, milliseconds, param1, param2, ...)

3.串行执行异步任务:then

<script>
    function cal(input) {
        return new Promise(function (resolve, reject) {
            setTimeout(resolve, 500, "add");
            console.log(input);
        });
    }

    function add(input) {
        return new Promise(function (resolve, reject) {
            setTimeout(resolve, 500, "cal");
            console.log(input);
        });
    }

    var p = new Promise(function (resolve, reject) {
        console.log('start');
        resolve("cal");
    });

    p.then(cal).then(add).then(cal);

</script>

<!--start-->
<!--3.Promise.html:6 cal-->
<!--3.Promise.html:13 add-->
<!--3.Promise.html:6 cal-->

4.并行执行异步任务:all

var p1 = new Promise(function (resolve, reject) {
    setTimeout(resolve, 500, 'P1');
});
var p2 = new Promise(function (resolve, reject) {
    setTimeout(resolve, 600, 'P2');
});

// 同时执行p1和p2,并在它们都完成后执行then:
Promise.all([p1, p2]).then(function (results) {
    console.log(results); // 获得一个Array: ['P1', 'P2']
});

5.竞争异步执行任务:race

var p1 = new Promise(function (resolve, reject) {
    setTimeout(resolve, 500, 'P1');
});
var p2 = new Promise(function (resolve, reject) {
    setTimeout(resolve, 600, 'P2');
});
Promise.race([p1, p2]).then(function (result) {
    console.log(result); // 'P1'
});

由于p1执行较快,Promise的then()将获得结果'P1'。p2仍在继续执行,但执行结果将被丢弃。
如果我们组合使用Promise,就可以把很多异步任务以并行和串行的方式组合起来执行。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值