9

您可以通过以下方式获取经过身份验证的用户的朋友列表:

https://graph.facebook.com/me/friends

有人知道如何按用户名排序列表吗?因为它不是默认的。文档中没有任何内容。

4

9 回答 9

12

我们只需在 javascript 中排序即可在多个应用程序中执行此操作。

function sortByName(a, b) {
    var x = a.name.toLowerCase();
    var y = b.name.toLowerCase();
    return ((x < y) ? -1 : ((x > y) ? 1 : 0));
}

var _friend_data = null
function lazy_load_friend_data(uid) {
  if (_friend_data == null) {    
    FB.api('/me/friends', function(response) {        
        _friend_data = response.data.sort(sortByName);
      }
    )
  }
}
于 2010-05-20T00:10:03.057 回答
5

想出了一个解决办法。最终,我们可能能够对图表结果进行排序。现在,我只是在做这个(javascript)。假设我从 PHP 会话中获得了“fb_uid”:

var friends = FB.Data.query("SELECT name, uid FROM user WHERE uid IN (SELECT uid2 FROM friend WHERE uid1={0}) ORDER BY name", parseInt(fb_uid));
friends.wait(function(rows){
    console.log(rows);
});
于 2010-05-19T02:07:35.243 回答
3

我认为整个 OpenGraph API 仍处于 FB Connect 的过渡阶段。在任何情况下,我都会在 FQL 中做一个很好的旧 order-by 查询,您仍然可以使用它。我无法想象一旦建立了开放式图形方式,就很难改变。

这个非常好的教程向您展示了如何做到这一点:

http://thinkdiff.net/facebook/php-sdk-graph-api-base-facebook-connect-tutorial/

$fql    =   "select name, hometown_location, sex, pic_square from user where uid=xxxxxxxxxxxxxxx";
$param  =   array(
        'method'     => 'fql.query',
        'query'      => $fql,
        'callback'   => ''
);
$fqlResult   =   $facebook->api($param);
于 2010-05-19T01:34:31.387 回答
2

在一次通话中使用 FQL。

SELECT uid, name FROM user WHERE uid IN 
(SELECT uid2 FROM friend WHERE uid1 = me()) 
ORDER BY name ASC
于 2013-11-05T10:34:58.243 回答
2

如果你在调用方这样做有什么问题。这意味着,在您从该图形 API 获得所有朋友之后,您可以将所有朋友放入一个排序的数据结构中,然后显示所有他们:)

于 2010-05-19T01:33:11.387 回答
1

对我来说是一个简单的 asort($friends); 工作正常;)

于 2011-03-15T17:12:07.743 回答
1
$friends = $facebook->api('me/friends');
foreach ($friends as $key=>$value) {
    sort($value);
    foreach ($value as $fkey=>$fvalue) {
      echo "<img src='https://graph.facebook.com/".$fvalue[id]."/picture' width='50' height='50' title='".$fvalue[name]."' />";     
    }
}
于 2011-01-04T13:37:36.913 回答
0
private function _compareFacebookFriends($a, $b)
{
    return strcasecmp($a['name'], $b['name']);
}

public function sortFacebookFriendsArray(&$array)
{
    usort($array, '_compareFacebookFriends');
}

/* Add here $facebook's initialization. Use Facebook PHP SDK */
$fbFriends = $facebook->api('/me/friends');
sortFacebookFriendsArray($fbFriends);
于 2011-03-24T20:53:30.807 回答
0

以@MainSocial 的回答为基础,但按姓氏排序,而不是仅按名字排序:

function sortByName(a, b) {
    var fn = function(x) { return x.name.toLowerCase(); };
    var ln = function(x) { return x.last_name.toLowerCase(); };
    if(ln(a) == ln(b)){
        if(fn(a) == fn(b)) {
            return 0;
        }
        return (fn(a) < fn(b)) ? -1 : 1;
    }
    return (ln(a) < ln(b)) ? -1 : 1;
}

function getFriendsList() {
    FB.api('/me/friends', {fields: 'name,id,last_name'}, function(response) {
        var friends = response.data.sort(sortByName);
        for (i=0; i<friends.length; i++) {
            $('body').append(friends[i].name + ' - ' + friends[i].id + '<br>');
        }
    });
}

getFriendsList()
于 2013-05-29T04:48:32.687 回答