ajax - 尝试使用 jQuery 访问 Instagram API

标签 ajax jquery instagram

我正在尝试使用 Instagram API,并在 do-while 循环中发出 AJAX 请求,直到 next_url 为 null。我想要这段代码做的就是通过发出连续的请求来获取所有关注者,直到完成为止。这段代码有什么问题?

当我删除 do-while 循环时,它不会给我一个错误,但是一旦我在循环中使用 AJAX 请求,它就永远不会停止。显然,$next_url 字符串没有更改为新获取的 next_url - 为什么?怎么了?

$(document).ready(function(e) {
        $('#fetch_followers').click(function(e) {
            var $next_url = 'https://api.instagram.com/v1/users/{user-id}/followed-by?access_token={access-token}&count=100';
            var $access_token = '{access-token}';
            var $is_busy = false;
            var $count = 0;
            do {
                while($is_busy) {}
                $.ajax({
                    method: "GET",
                    url: $next_url,
                    dataType: "jsonp",
                    jsonp : "callback",
                    jsonpCallback: "jsonpcallback",
                    success: function(data) {
                        $is_busy = true;
                        $.each(data.data, function(i, item) {
                            $("#log").val($("#log").val() + item.id + '\n');
                        });
                        $("#log").val($("#log").val() + data.pagination.next_url + '\n');
                        $next_url = data.pagination.next_url;
                    },
                    error: function(jqXHR, textStatus, errorThrown) {
                        $is_busy = true;
                        //alert("Check you internet Connection");
                        $("#log").val($("#log").val() + 'Error\n');
                    },
                    complete: function() {
                        ++$count;
                        $is_busy = false;
                    }
                });
            } while($next_url !== '' || $count <= 50);
        });
    });

在我的逻辑失败后,我添加了可以中断 do-while 循环的 $count 变量,因为 do-while 循环无限运行。添加后仍然无限运行,不知道为什么。

最佳答案

让函数在 ajax 成功回调中调用自身,并将新的 url 作为参数:

$(document).ready(function() {
    $('#fetch_followers').click(function() {
        var $access_token = '{access-token}';
        pollInstagram('https://api.instagram.com/v1/users/{user-id}/followed-by?access_token={access-token}&count=100');
    });
});

function pollInstagram(next_url, count) {
    $.ajax({
        method: "GET",
        url: next_url,
        dataType: "jsonp",
        jsonp: "callback",
        jsonpCallback: "jsonpcallback",
        success: function(data) {
            $.each(data.data, function(i, item) {
                $("#log").val($("#log").val() + item.id + '\n');
            });
            $("#log").val($("#log").val() + data.pagination.next_url + '\n');

            // If the next url is not null or blank:
            if( data.pagination.next_url && count <=50 ) {
                pollInstagram(data.pagination.next_url, ++count);
            }
        },
        error: function(jqXHR, textStatus, errorThrown) {
            //alert("Check you internet Connection");
            $("#log").val($("#log").val() + 'Error\n');
        }
    });
}​

关于ajax - 尝试使用 jQuery 访问 Instagram API,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11712106/

相关文章:

python - 使用 python-instagram 库获取最新的 Instagram 用户照片

javascript - AJAX 调用后 PHP 结果不显示

JavaScript 水平旋转器

javascript - 使用带有 laravel 的 ajax 提交表单时避免页面重新加载

IE9+ 中带填充的 jQuery UI .addClass() 动画

javascript - RowReorder 扩展不保存行的位置

ios - Instagram 应用程序接口(interface)。在 Swift 3.0 中请求 access_token

javascript - 从js脚本发送数据到当前的php文件

javascript - asp.net 中的按钮有时不起作用

javascript - instafeed.js 获取特定用户喜欢的媒体列表