Mic*_*fer 2 javascript recursion facebook-graph-api facebook-javascript-sdk es6-promise
我目前正在开发一个使用Facebook Graph API的网络应用程序.
我想要实现的是获取用户的所有帖子.
但是,这并不容易,因为我必须对结果进行分页.
目前,我正在兑现承诺.
我试图实现的是用post对象填充数组.
因此,我使用的promises和递归不能按预期工作.
我的代码目前看起来如下:
// Here I retrieve the user with his or her posts,
// just the first 25 due to pagination
if (accessToken) {
return new Promise(resolve => {
FB.api('/me?fields=id,name,posts&access_token=' + accessToken, response => {
this.get('currentUser').set('content', response);
resolve()
})
})
}
// Returns all posts of a given user
function getAllPostsOfUser(posts, postsArr) {
// Process each post of the current pagination level
for (var post of posts.data) {
// Only store meaningful posts
if (post !== undefined && post.message !== undefined) {
postsArr.push(post)
}
}
// Further posts are retrievalable via paging.next which is an url
if (posts.data.length !== 0 && posts.paging.next !== undefined) {
FB.api(posts.paging.next, response => {
getAllPostsOfUser(response, postsArr)
resolve()
})
}
return postsArr
}
var posts = getAllPostsOfUser(this.get('currentUser').content.posts, [])
// I want to use all the posts here
console.log(posts)
Run Code Online (Sandbox Code Playgroud)
我遇到的问题是我想使用放置console.log的帖子,但是当我记录posts数组时,很多帖子都丢失了.
我确信我的承诺做错了但我不知道是什么.
如果有人能引导我找到解决方案,我会很高兴.
先感谢您.
试试这个:
function getAllPosts() {
return new Promise((resolve, reject) => {
let postsArr = [];
function recursiveAPICall(apiURL) {
FB.api(apiURL, response => {
if (response && response.data) {
//add response to posts array (merge arrays), check if there is more data via paging
postsArr = postsArr.concat(response.data);
if (response.paging && response.paging.next) {
recursiveAPICall(response.paging.next);
} else {
resolve(postsArr);
}
} else {
reject();
}
})
}
recursiveAPICall('/me/posts?fields=message&limit=100');
}
}
getAllPosts().then(response => {
console.log(response);
}).catch(e => {
console.log(e);
});
Run Code Online (Sandbox Code Playgroud)
没有经过测试,只是我提出的一个简单例子.它返回一个promise并使用递归函数来获取所有条目.顺便说一下,你不需要添加访问令牌.如果您已登录,SDK将在内部使用它.