我正在尝试在按钮单击时为用户显示FB.ui对话框。现在,我可以让对话框显示为弹出窗口,但我不希望这样。我希望对话框显示为模式,以便弹出窗口阻止程序不会阻止它。我尝试过使用“display:'iframe'”参数,但在使用时我收到错误:
“对话框”模式只能在用户连接时使用。
我已经读过,或许我需要使用访问令牌来使其显示为模态并使用display iframe参数。请记住这是一个网站。
我已经在服务器端(PHP)的Laravel中有一个OAuth2包,负责验证Facebook用户,并提取访问令牌。我的问题是,如何提取此令牌并将其应用于Javascript SDK,以便我可以将FB.ui对话框显示为模式?我甚至需要这样做吗?这是我正在使用的JavaScript:
window.fbAsyncInit = function () {
FB.init({ appId: '************', cookie: true, status: true, xfbml: true, oauth: true });
if (typeof facebookInit == 'function') {
facebookInit();
}
};
(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));
function facebookInit() {
FB.ui({
url : 'http://url.com',
method: 'feed',
name: 'Url',
link: url,
display: 'iframe',
picture: 'http://thisimage.png',
caption: fb_description,
}, function (response) {
if (response && response.post_id) {
window.location = "/artists";
} else {
window.location = "/artists";
}
});
}
答案 0 :(得分:1)
我也有这个问题 - 事实证明我没有在我的Facebook应用设置上指定localhost
域名。添加之后,它运行正常。