javascript - 使用 facebook api 获取专辑封面

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

我正在尝试通过 JavaScript 和 Graph API 从 facebook 获取相册列表。我是这样做的:

FB.api('/me/albums', function(response){
    //
});

专辑封面作为照片 ID 返回,而不是我可以插入到 html 中的 url。所以,我需要在第二步获得一个网址。但是,根据应用程序设计,我以后无法获取 URL 并插入图像。我需要返回一个包含专辑属性(id、名称、封面 url)的完整数据对象。下面列出了我最后一次尝试:

FB.api('/me/albums', { fields : 'id,name,count,cover_photo' }, function(response){

    if (!response || response.error) {
        callback.call(false);
        return;
    };

    var parsed = $(response.data).map(function(){

        if (this.count > 0) {

            var result = {
                aid : this.id,
                title : this.name,
                cover : this.cover_photo
            };

            return result;
        };
    });

    for (var i = 0; i < parsed.length; i++) {

        (function(i){

            FB.api('/' + parsed[i].cover, { type : 'album' }, function(response){
                parsed[i].thumb = response.picture;
            });

        })(i);

    };

    callback.call(parsed);
});

问题是循环没有等待覆盖查询并继续前进,留下没有覆盖 url 的返回对象。我认为这不是那么困难,但我找不到足够长的解决方案。欢迎任何想法。

最佳答案

window.getAlbums = function() {
FB.api({
     method: 'fql.multiquery',
     queries: {
        query1: 'select aid,name,link,photo_count,cover_object_id from album where owner = me()',
        query2: 'SELECT pid,src FROM photo WHERE object_id  IN (SELECT cover_object_id FROM #query1)'
     }
    },
    function(response) {
        var parsed = new Array();
        $(response[0].fql_result_set).each(function(index,value){
                var result = {
            aid : value.aid,
            title : value.name,
            cover : response[1].fql_result_set[index].src,
                            link :value.link
        };
                parsed.push(result);
        })
    getdata(parsed);
});

};

应用您的相册详细信息使用

function getdata(data){

$(data).each(function(index,value){
    // console.log(value.aid + ' - '+ value.cover+ ' - '+ value.title );
    $("#fb_albumb").append('<h3>'+ value.title +'</h3><a href="'+ value.link  +'" target="_blank" ><img src="'+ value.cover +'" title="'+ value.title +'" /></a><br/>');
})

HTML

<fb:login-button scope="user_photos" onlogin="getAlbums()">Grant Permissions to Allow access to Photos and Albums</fb:login-button>

也许这会对你有所帮助。

关于javascript - 使用 facebook api 获取专辑封面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11949188/

相关文章:

javascript - 名称的正则表达式模式在 adobe cq5 中不起作用

javascript - JavaScript 函数运行时显示消息

javascript - Canvas Web 应用程序提要对话框

javascript - 如何创建 Facebook 应用程序并将其连接到我的旧 Facebook 页面

javascript - Typescript - 如何将部分类型分配给另一个对象的相同类型的属性?

javascript - 检查销售订单(客户 PO)上是否有重复项 保存

javascript - 将字符串作为参数传递时,string.charAt() 是如何工作的?

ruby-on-rails - 升级 Rails 应用程序以支持 Facebook SSL 的最佳方式是什么?

javascript - 上传 Base64 图片 Facebook Graph API

authentication - 管理 Facebook 身份验证 token