Sta*_*y J 4 javascript facebook-graph-api facebook-login angularjs
我使用以下代码进行Facebook登录api: -
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.';
}
};
function checkLoginState() {
FB.getLoginStatus(function(response) {
statusChangeCallback(response);
});
};
window.fbAsyncInit = function() {
FB.init({
appId : '924067597708287',
cookie : true,
xfbml : true,
version : 'v2.5'
});
FB.getLoginStatus(function(response) {
statusChangeCallback(response);
});
};
(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);
console.log('Successful login for: ' + response.id);
console.log('Successful login for: ' + response.picture);
document.getElementById('status').innerHTML =
'Thanks for logging in, ' + response.name + '!';
document.getElementById('pic').innerHTML =
'Your user id is : ' + response.id + "<br />" +
"<img src='" + "https://graph.facebook.com/" + response.id + "/picture?type=large' alt='' />";
});
};
Run Code Online (Sandbox Code Playgroud)
当我在角度控制器中放置相同的代码时,我收到一条错误消息
checkLoginState is not defined
Run Code Online (Sandbox Code Playgroud)
登录过程停止,但是当我刷新时,它会显示已登录.
请帮忙.
一旦你checkLoginState进入控制器,它是否超出了FB(sdk.js)的范围.所以,在窗口上定义它(你需要注入$window).
$window.checkLoginState = function() {
FB.getLoginStatus(function(response) {
console.log("checkLoginState: "+response);
});
}
Run Code Online (Sandbox Code Playgroud)
然后,您应该在每次单击后在控制台中看到此信息,这会告诉您FB可以访问该功能:
checkLoginState: [object Object]
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1933 次 |
| 最近记录: |