hezi100_2017 2021-08-09 10:20 采纳率: 92.3%
浏览 72
已结题

js中无法实现函数f1()运行完成后再运行f2()

我想实现函数f1()运行完成后,再运行f2(),因为小程序有时不是顺序执行的,所以我参照网上的用下面方法,可是 却还是不能实现,请问应该如何修改代码才能实现等f1()执行完后再执行f2()呢,请教各位!
async f2(){
try{
await f1()
}
catch(e){

 }

}

  • 写回答

5条回答 默认 最新

  • CSDN专家-showbo 2021-08-09 10:34
    关注

    不是小程序不按照顺序,是应为你的f1使用了异步执行的方法,如setTime,setInterval或者wx.request之类,这样是不会等待异步执行完毕后再执行f2,按照顺序执行,用下面2种方法中其中一种来解决
    可以用Promise,代码如下,有帮助麻烦点个采纳【本回答右上角】,谢谢~~

    
        function f1() {
            console.log('进入f1,里面包含异步方法')
            return new Promise(function (resolve, reject) {//异步代码放到Promise中
                setTimeout(function () {//setTimeout模拟异步方法
                    console.log('异步执行完毕')
    
                    resolve('ok');//执行成功调用resolve,会执行then回调
                    //执行异步失败调用reject,会执行Promise catch回调
                    //reject('执行失败')
    
    
                }, 3000) })
    
        }
        function f2(f1result) {
            console.log(f1result, '执行f2')//ok 执行f2
        }
        f1().then(f2).catch(function (err) { console.log('f1执行失败:' + err) });
    

    第一次接触Promise不好理解就用平时常用的回调形式,把f2当参数传入f1,f1异步执行完毕后执行f2

        function f1(callback) {
            console.log('进入f1,里面包含异步方法')
            setTimeout(function () {//setTimeout模拟异步方法
                console.log('异步执行完毕');
                callback('执行回调');
            }, 3000);
    
        }
        function f2(f1result) {
            console.log(f1result, '执行f2')//ok 执行f2
        }
        f1(f2)///
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 8月15日
  • 已采纳回答 8月11日
  • 创建了问题 8月9日

悬赏问题

  • ¥15 用hfss做微带贴片阵列天线的时候分析设置有问题
  • ¥50 我撰写的python爬虫爬不了 要爬的网址有反爬机制
  • ¥15 Centos / PETSc / PETGEM
  • ¥15 centos7.9 IPv6端口telnet和端口监控问题
  • ¥120 计算机网络的新校区组网设计
  • ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作
  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 海浪数据 南海地区海况数据,波浪数据
  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等