等待直到所有回调都被调用

时间:2019-02-22 21:09:21

标签: javascript react-native callback connectycube

我在react native中有一个组件,可显示用户的所有聊天记录。主要逻辑必须在componentDidMount()中。这里是一个简化的版本:

componentDidMount(){
     ConnectyCube.chat.list({}, function(error, dialogs) {
        chats = dialogs.map(chat => {
            const opponentId = //some logic
            ConnectyCube.users.get(function(error, res){
                //some logic to populate chats 
            });
            }
        )

        this.setState({chats: chats})
        }
    );
}

换句话说,主要问题是我不知道如何使用多个回调(用户每次聊天都有一个回调)来处理数据结构“聊天”,以便最后设置setState。 也许是我的问题,因为我是事件驱动方法的新手,所以我正在以同步方式进行思考。任何帮助表示赞赏。

1 个答案:

答案 0 :(得分:1)

在这里,您可以跟踪剩余请求的数量,并在所有请求完成后触发一些代码。请注意,这几乎就是Promise.all所做的。

//some kind of global or component level variable, tracks the number of pending requests left
var remaining = 0;

componentDidMount(){
     ConnectyCube.chat.list({}, function(error, dialogs) {
        // set remaining to how many dialogs there are
        remaining = dialogs.length;
        chats = dialogs.map(chat => {
            const opponentId = //some logic
            ConnectyCube.users.get(function(error, res){
                //some logic to populate chats

                // decrement remaining and check if we're done
                if (--remaining === 0) {
                  finalCallback(); // in here you do your setState.
                }
            });
            }
        )

        this.setState({chats: chats})
        }
    );
}