Почему не работает всплывающее окно facebook stream.share в Safari? - PullRequest
1 голос
/ 03 февраля 2011

Я пытаюсь заняться этим с прошлой недели, и, судя по всему, я не могу заставить это работать на 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>

1 Ответ

1 голос
/ 04 февраля 2011

После многих испытаний и разочарований. Коллега отметил, что «feed» - это новый способ создания «stream.publish». Это решило проблему.

Редактировать: устаревший ответ.

...