Я пытаюсь заняться этим с прошлой недели, и, судя по всему, я не могу заставить это работать на Safari, все другие браузеры отображают всплывающее окно, кроме Safari.
Кажется, достаточно просто, загрузите javascript-sdk
асинхронно, запустите его и вызовите FB.ui
с помощью метода stream.publish. Дело в том, что я знаю, что этот код должен работать в сафари, потому что пример здесь http://fbrell.com/fb.ui/stream.share.
Я использую этот заголовок P3P, который мы используем для решения проблемы с IE7:
Response.AddHeader("P3P", "CP=\"NON DSP COR DEVa PSAa IVAo CONo OUR IND UNI PUR NAV DEM LOC\", " + "policyref=\"http://sweepstakes.mars.com/w3c/p3p.xml\"");
Я надеюсь, что кто-то может предложить волшебный совет, который заставит это работать. Вот мой код:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:og="http://opengraphprotocol.org/schema/" xmlns:fb="http://www.facebook.com/2008/fbml">
<head id="Head1" runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>test</title>
</head>
<body>
<div id="fb-root">
</div>
<script>
window.fbAsyncInit = function (){
FB.init({ appId: '<%= Common.appID %>', status: true, cookie: true,
xfbml: true
});
var publish = {
method: 'stream.publish',
message: 'test',
display: 'dialog'
};
FB.ui(publish);
};
(function () {
var e = document.createElement('script'); e.async = true;
e.src = document.location.protocol +
'//connect.facebook.net/en_US/all.js';
document.getElementById('fb-root').appendChild(e);
}());
</script>
</body>
</html>