疯狂使用 Titanium 中的异步调用

Going crazy with async calls in Titanium

在花了 6 个小时尝试不同的方法来解决我的问题后,我总是得到同样的错误并且无法弄清楚原因。

问题很容易理解:我在 Appcelerator Titanium ACS 中保存了 10 个用户,我想创建 10 个记录,每个用户一个。

事情一定很简单:所有用户都有相同的通行证,所以我只需要用每个人登录,以用户身份创建对象,就是这样!! (在 ACS 中,对象由创建它们的用户拥有(并自动分配 user_id)。

为了管理异步,我使用带有回调的函数来等待结束。

var Cloud = require('ti.cloud');

function createObject(value, onComplete) {
    Cloud.Objects.create({
        classname: 'MyObj',
        session_id: Cloud.sessionId,
        fields: {
            value: value
        }
    }, function(data) {
        if (data.success) {
            Ti.API.info('New value: user [' + data.Scores[0].user_id + '] - value: ' + data.Scores[0].value);
            onComplete(true);
        } else {
            Ti.API.info('Error: ' + data.message);
            onComplete(false);
        }
    });
}

function login(user, onComplete) {
    Cloud.Users.login({
        login: user.username,
        password: '1234'
    }, function(e) {
        if (e.success) {
            createObject(20, function(cb) {
                onComplete(true);
            });
        } else {
            Ti.API.warn('Error login user: ' + e.message);
            onComplete(false);
        }
    });
}

// Get target users
Cloud.Users.query({
    response_json_depth: 1
}, function(data) {
    if (data.success) {
        _.each(data.users, function(user) {
            login(user, function(cb) {
                Ti.API.warn("user: " + user.username);
            });
        });
    }
});

好吧,我的结果总是一样的:

Ti.API.warn('user: ' + user.username); 显示正确的用户名(一个接一个),但 Ti.API.info('New value: user [' + data.Scores[0].user_id + '] - value: ' + data.Scores[0].value); 始终显示同一用户,这意味着所有值都为同一用户保存(在数据库中检查,是都是同一个用户),而不是每个用户 1 个值。

我也尝试在 _.each 命令中使用异步,但结果相同。

问题出在哪里?我想我正在等待 _.each 用户登录,登录必须等待完成 createObject,但似乎我做错了什么。

这里是出口。对我来说没有意义...:[=​​14=]

New value: user [54cb62cf18beba0935422a35] - value: 20
user: krusty
New value: user [54cb62cf18beba0935422a35] - value: 20
user: apu
New value: user [54cb62cf18beba0935422a35] - value: 20
user: ned

注:所有调用保存的user_id对应用户NED(最后一个)

这是 ACS 中的错误。无论如何,目前无所谓,因为5年前就修好了。