es6使用websocket同步等待方法

本文介绍了JavaScript中Promise的基本使用方法及其如何实现同步等待操作。同时深入探讨了ES6引入的async/await关键字,展示了如何利用它们编写更简洁、易读的异步代码。文章还特别关注了如何通过Promise与async/await结合处理WebSocket等回调函数,实现真正的同步等待。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

之前对于Promise相当不了解,同步等待函数都是用的其他的库,后面发现es原生的Promise其实完全可以支持同步等待操作,以此记录,希望后面人少走弯路。

promise

Promise的参数是一个函数,函数就是要等待执行的什么内容,这个函数的参数有两个,一个是resolve,一个是reject。通过主动调用resolve就可以控制promise的结束。

Promise(funciton(resolve, reject){
    resolve();
})

async/await

es6有了一个新的关键字 await/async,可以达到编写同步代码的目的。比如等待时间到了执行后面的内容就可以写成

async waitOneSecondToExe(){
    await setTimeout(function(){}, 1000);
    doSomething();
}

await同步等待的内容是一个Promise对象,当然不是Promise对象await也不会报错,但是也没有任何作用了。

同步等待一个回调函数

await一个函数好理解,但是await一个回调函数怎么办呢。我现在想等待websocket返回结果再执行后面的内容如何做呢?

//socket接收到数据然后执行doSomething
function recvData(){
    socket.on("recvData", function(data){
        console.log(data);
    });
    doSomething();   
}

如上面的代码肯定是不行的,recvData中的socket.on函数仅仅是进行了注册,我的期待是doSomething在socket接收到数据后才执行,那么怎么办呢?

async function recvData(){
    await new Promise((resolve) => 
        {
            socket.on("recvData", function(data){
                console.log(data);
                resolve();
            })
        });
    doSomething();
}

通过主动调用resolve函数,会把Promise内部的状态设置为已完成,await等待的Promise就会得到结果,执行下面的程序内容。达到同步等待会调函数的目的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值