javascript - Angular Facebook 服务达到 API 调用限制

标签 javascript angularjs facebook facebook-graph-api facebook-javascript-sdk

我试图在 ng-repeat 内调用我的 Facebook 服务,但不知何故 Facebook API 调用限制很快就达到了。

我有这样的服务:

angular.module('core').factory('Facebook', ['$q',
    function ($q) {
        return {
            getMutualFriends: function (fbUserId) {
                var deferred = $q.defer();

                var path = "/" + fbUserId;

                FB.api(
                    path,
                    {
                        'fields': 'context.fields(mutual_friends)'
                    },
                    function (response) {
                        if (!response || response.error) {
                            deferred.reject('Error occured');
                        } else {
                            deferred.resolve(response);
                        }
                    }
                );
                return deferred.promise;
            }
        };
    }
]);

在我的 Controller 中,我有一个调用服务的函数:

$scope.getMutualFriendsCount = function (fbUserId) {
    if (fbUserId === '' || fbUserId === undefined) return 0;

    Facebook.getMutualFriends(fbUserId)
        .then(function (response) {
            // untested response
            return response.context['mutual_friends']['summary']['total_count'];
        });
}

在我的模板中,我有 data-ng-repeat="profile inprofiles" 并且对于每个配置文件,我尝试绑定(bind)结果 data-ng-bind=getMutualFriends(profile .fbId).

该服务设法与 FB 服务器进行通信,直到我开始注意到循环期间有太多调用,并且很快就达到了调用限制(在我的开发计算机上仅在 20 个配置文件页面上进行 1 或 2 次刷新) )。有谁知道我如何更好地设计为多个 ID 获取共同好友的方法?

最佳答案

您不应该调用从监视表达式发出 HTTP 请求的函数,无论是 ng-bind 还是等效的 {{ }}。此表达式以及后续的 HTTP 调用将在每个摘要周期中调用 - 显然不是您所期望或需要的。

相反,获取所需的数据并将其存储在每个配置文件中,然后从ng-repeat中访问该值。

此外,根据上面的评论,您应该考虑批量调用 Facebook。创建一个单独的服务来处理所有这些复杂性并向 Controller 公开一个简单的 API。

关于javascript - Angular Facebook 服务达到 API 调用限制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29852970/

相关文章:

android - 获取当前用户喜欢帖子的状态

java - 使用 Eclipse 在 android 中获取 java.lang.NoClassDefFoundError

javascript - onblur,仅在 jquery 和 javascript 中工作一次

javascript - 如何解决移动网站 map 缩放和页面缩放冲突?

javascript - AngularJS 对自定义指令的单向绑定(bind)

javascript - AngularJS,如何从输入中获取值并将其放入工厂中?

ajax - 单页应用程序和开放图谱

javascript - 创建元素节点、设置其属性并附加元素?

javascript - 从 OpenGraph 预览中再现视频 - 类型 "text/html"

javascript - 如何在 angular.js 中添加带有过滤器返回值的数字