• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

javascript - 在 ios ionic 应用程序中使用 javascript promise

[复制链接]
菜鸟教程小白 发表于 2022-12-11 17:07:24 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我需要在 ionic 中使用以下 promise (ios 显然在 android 上没问题):

var Attendees = Parse.Object.extend("Attendees");

    return Promise.all(eventDetails.map(detail => {
        return Promise.all([new Promise((res, rej) => {
            var query2 = new Parse.Query(Attendees);
            query2.equalTo("event_id", detail .id_event);    
            query2.count({
                success: function(number) {
                    detail["n_requests_received"] =  number;
                    alert("received")
                    res('Some value if required'); //These are needed or promise chain will hang
                }
            });
        }),
        new Promise((res, rej) => {
            var query3 = new Parse.Query(Attendees);
            query3.equalTo("event_id", detail .id_event);
            query3.equalTo("status", "confirmed")
            query3.count({
                success: function(number) {
                    detail["n_requests_confirmed"] =  number;
                   // alert("confirmed")
                   res('Some value if required'); //These are needed or promise chain will hang
                }
            });
        })]);
    }));

你知道怎么做吗?



Best Answer-推荐答案


我使用 deferred 是为了让你可以运行一个 Promise 链,而不是将它们分开。如果调用发生错误,您还需要处理错误情况(两个 Promise 使用相同的错误函数)。它会正确地拒绝 promise ,以便您妥善处理。

var promises = [];

eventDetails.forEach(function(detail) {
    var deferred = $q.defer();

    new Parse.Query('Attendees')
    .equalTo("event_id", detail.id_event) 
    .count().then(function(number) {
        detail["n_requests_received"] =  number;
        alert("received");
        return new Parse.Query('Attendees')
        .equalTo("event_id", detail .id_event)
        .equalTo("status", "confirmed")
        .count();
    }).then(function(confirmedCount) {
        detail["n_requests_confirmed"] = confirmedCount;
        deferred.resolve('I have resolved this promise');
    }, function(err) {
        console.error(JSON.stringify(err));
        deferred.reject('Error: ' + JSON.stringify(err));
    });

    promises.push(deferred.promise());
});

$q.all(promises).then(function(res) {
    // completed all promises w/ no errors
}, function(err) {
    console.error(JSON.stringify(err));
});

关于javascript - 在 ios ionic 应用程序中使用 javascript promise ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38618329/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap