让异步操作同步执行的方法详解

 下面我们看一个最简单的例子, 我的需求是要在fn1函数外面打印msg

        function fn1() {
            setTimeout(function () {
                msg = '你等我一下我  3s';
            }, 3000);
        }
        fn1();

那么怎么样才能在fn函数中获取到msg呢
通过回调函数
  function fn1(callBack) {
            setTimeout(function () {
                msg = '你等我一下我 3s';
                callBack(msg);//回调
            }, 3000);
        }

 fn1(function (c) {
      alert(c)
 })

 es6

 fn1(c => {
     alert(c)
 })

promise 将异步请求改成promise 通过.then()的方式 进行调用

function fn1() {
    return new Promise((resolve, reject) => {
        setTimeout(() => {
            msg = '你等我一下我 3s';
            resolve(msg)
        }, 3000);
    })
}

//通过.then()的方式 进行调用
fn1().then(res => {
    alert(res)
})

通过await 和async来处理

   function fn1() {
            return new Promise((resolve, reject) => {
                setTimeout(() => {
                    msg = '你等我一下我 3s';
                    resolve(msg)
                }, 3000);
            })
        }

        async function passpro() {
            let res = await fn1();
            alert(res)
        }

        passpro();

async函数返回的是一个Promise对象

如果一个函数加了async关键词,这个函数又有返回值,
在调用这个函数时,如果函数执行成功,
内部会调用Promise.solve()方法返回一个Promise对象.

如果函数执行出现异常,
就会调用Promise.reject()方法返回一个promise 对象
posted @   南风晚来晚相识  阅读(2978)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
历史上的今天:
2019-05-31 vue+elementUI+node实现登录模块--验证用户名是否正确
点击右上角即可分享
微信分享提示