在facebook graph api中使用javascript获取facebook用户数据

在facebook graph api中使用javascript获取facebook用户数据,javascript,facebook,facebook-graph-api,Javascript,Facebook,Facebook Graph Api,我只想使用alert显示已登录用户的姓名,并在未登录时提示用户登录。 请帮帮我,我已经在线4个小时没有收到facebook graph api 这是facebook.com上的代码 我不知道如何准确地操作这段代码。我试着在结尾加上三行 <script> function statusChangeCallback(response){ console.log('statusChangeCallback'); console.log(response); if (response.st

我只想使用
alert
显示已登录用户的姓名,并在未登录时提示用户登录。 请帮帮我,我已经在线4个小时没有收到facebook graph api 这是facebook.com上的代码 我不知道如何准确地操作这段代码。我试着在结尾加上三行

<script>
function statusChangeCallback(response){
console.log('statusChangeCallback');
console.log(response);

if (response.status === 'connected') {
testAPI();
} else if (response.status === 'not_authorized') {
document.getElementById('status').innerHTML = 'Please log ' + 'into this app.';
} else {
document.getElementById('status').innerHTML = 'Please log ' + 'into Facebook.';
}
}

// This function is called when someone finishes with the Login
// Button. See the onlogin handler attached to it in the sample
// code below.
function checkLoginState() {
FB.getLoginStatus(function(response) {
statusChangeCallback(response);
});
}

window.fbAsyncInit = function() {
FB.init({
appId : '1608304139394721',
cookie : true, // enable cookies to allow the server to access the session
xfbml : true, // parse social plugins on this page
version : 'v2.0' // use version 2.0
});

FB.getLoginStatus(function(response) {
statusChangeCallback(response);
});
};

// Load the SDK asynchronously
(function(d, s, id) {
var js, fjs = d.getElementsByTagName(s)[0];
if (d.getElementById(id)) return;
js = d.createElement(s); js.id = id;
js.src = "//connect.facebook.net/en_US/sdk.js";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));
function testAPI() {
console.log('Welcome! Fetching your information.... ');
FB.api('/me', function(response) {
console.log('Successful login for: ' + response.name);
document.getElementById('status').innerHTML ='Thanks for logging in, ' + response.name + '!';
name=response.name;
alert(name);
});
}
</script>

<fb:login-button scope="public_profile,email" onlogin="checkLoginState();"></fb:login-button>

您的代码有效且工作正常,在
JavaScript
中,代码一行接一行地执行,当当前执行的行上出现错误时,代码停止执行,您的错误是: 状态id属性“>

正如您在代码中可以看到的那样,您的
警报(名称)
位于发生该错误的那一行之后 状态id属性“>

解决方案

在文档中添加一个id为
status
的元素(
div
)非常简单,可以避免该错误

<div id="status"></div>

或者使用jQuery作为DOM选择器

<div id="status"></div>