gpt4 book ai didi

javascript - 等到所有回调都被调用

转载 作者:行者123 更新时间:2023-11-29 23:05:38 26 4
gpt4 key购买 nike

我在 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})
}
);
}

换句话说,主要问题是我不知道如何使用多个回调(一个用于用户的每个聊天)来处理数据结构“聊天”以便在最后设置状态。也许,我的问题是,我正在以同步方式思考,因为我是事件驱动方法的新手。感谢您的帮助。

最佳答案

您可以通过以下方法跟踪剩余请求的数量,并在它们全部完成时触发一些代码。注意,这几乎就是 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})
}
);
}

关于javascript - 等到所有回调都被调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54835218/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com