我正在尝试使用Gravity Forms制作一个WordPress提交表单,其中访问者看到“使用Facebook登录”按钮。
一旦访问者登录并授予权限,该部分就会刷新以显示Facebook用户个人资料链接和图片,让访问者知道他们正在使用Facebook个人资料提交。
我已经复制了代码,但我需要一些帮助来完成它。
<div id="fb-root"></div>
<script>
window.fbAsyncInit = function() {
FB.init({
appId : 'XXXXXXXXXXXXXXXXX', // App ID
channelUrl : '//www.MY-DOMAIN.com/channel.html', // Channel File
status : true, // check login status
cookie : true, // enable cookies to allow the server to access the session
xfbml : true // parse XFBML
});
// Additional initialization code here
};
// Load the SDK Asynchronously
(function(d){
var js, id = 'facebook-jssdk'; if (d.getElementById(id)) {return;}
js = d.createElement('script'); js.id = id; js.async = true;
js.src = "//connect.facebook.net/en_US/all.js";
d.getElementsByTagName('head')[0].appendChild(js);
}(document));
</script>
<script>
FB.api('/me', function(user) {
if (user) {
var image = document.getElementById('image');
image.src = 'http://graph.facebook.com/' + user.id + '/picture';
var name = document.getElementById('name');
name.innerHTML = user.name
}
});
</script>
现在,我该怎么做才能获得可以显示“登录按钮”的部分,然后在有人登录后显示用户个人资料链接?
答案 0 :(得分:0)
登录时,您可以使用以下方法之一:
FB.login
JavaScript SDK 答案 1 :(得分:0)
您在页面加载时调用API太早了。首先,需要在facebook脚本准备好运行之后完成。您可以将代码放入fbAsyncInit()函数中。其次,您应该遵循此范例以确保用户登录到您的应用,请参阅:https://developers.facebook.com/docs/reference/javascript/FB.getLoginStatus/