在 javascript 中获取应用程序用户
我正在尝试在 javascript sdk 中获取应用程序用户。 为什么这不起作用?
var q = FB.Data.query('SELECT uid FROM user WHERE uid IN '
+ '(SELECT uid2 FROM friend WHERE uid1 = me()) AND is_app_user = 1');
q.wait(function(resp) {
console.log(resp);
}
);
返回 []
但是效果很好:
var q = FB.Data.query('SELECT uid2 FROM friend WHERE uid1 = me()');
q.wait(function(resp) {
var l = [];
for (var i in resp) {
l.push(resp[i].uid2)
}
var fql = 'SELECT uid FROM user WHERE uid IN (' + l.join(',') + ') and is_app_user = 1';
var q1 = FB.Data.query(fql);
q1.wait(function(resp) {
console.log(resp);
});
}
);
第二个语句的问题在于将所有朋友加载到浏览器中,并且它又发出了一个请求。为什么第一个语句不起作用?
I'm trying to get app users in javascript sdk.
Why this is not working?
var q = FB.Data.query('SELECT uid FROM user WHERE uid IN '
+ '(SELECT uid2 FROM friend WHERE uid1 = me()) AND is_app_user = 1');
q.wait(function(resp) {
console.log(resp);
}
);
That returns []
However that works well:
var q = FB.Data.query('SELECT uid2 FROM friend WHERE uid1 = me()');
q.wait(function(resp) {
var l = [];
for (var i in resp) {
l.push(resp[i].uid2)
}
var fql = 'SELECT uid FROM user WHERE uid IN (' + l.join(',') + ') and is_app_user = 1';
var q1 = FB.Data.query(fql);
q1.wait(function(resp) {
console.log(resp);
});
}
);
The problem with the second statement is that loads all friends into browser and it makes one more request. Why isn't the first statement working?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
尝试将 is_app_user 视为布尔值:
(仅使用 fql 对我有用)
var q = FB.Data.query('SELECT uid FROM user WHERE uid IN '
+ '(从朋友中选择 uid2,其中 uid1 = me()) AND is_app_user');
try treating is_app_user as a boolean:
(works for me using just fql)
var q = FB.Data.query('SELECT uid FROM user WHERE uid IN '
+ '(SELECT uid2 FROM friend WHERE uid1 = me()) AND is_app_user');
尝试 FB.api。请参阅旧 REST API 调用部分:
上面 + fql.query = 成功:)
Try FB.api. See section: Old REST API calls:
Above + fql.query = success:)