1

我正在为 facebook 功能创建自定义共享,这比我最初想象的要复杂。

我必须创建一个 facebook 应用程序,然后使用它的 ID 来启动它。

如果您尝试在 facebook 上分享页面,它会让您登录到 facebook(如果未登录),然后它会请求访问您的个人资料(仅在您的第一次分享时),然后继续分享对话以让您分享它。

但是我注意到其他网站,包括 youtube 和 BBC,他们不请求访问在 facebook 上共享,而是直接将您带到共享对话。

有没有办法做到这一点?

使用代码如下:

<script type="text/javascript" src="http://connect.facebook.net/en_US/all.js"></script>
<script>
    FB.init({
        appId      : '*APP_ID*', // App ID
        status     : true, // check login status
        cookie     : true, // enable cookies to allow the server to access the session
        xfbml      : true,  // parse XFBML
        link       : '*LINK*'
    });
    $('.share-print .facebook > a').click(function(e){
        e.preventDefault();

        FB.getLoginStatus(function(response) {
            if (response.status === 'connected') {
                facebookSend();
                var uid = response.authResponse.userID;
                var accessToken = response.authResponse.accessToken;
            } else if (response.status === 'not_authorized') {
                // the user is logged in to Facebook, 
                // but has not authenticated your app
                FB.login(function(response) {
                    if (response.authResponse) {
                        console.log('Logged in');
                        facebookSend();
                    } else {
                        console.log('Not logged in');
                    }
                });
            } else {
                // the user isn't logged in to Facebook.
                FB.login(function(response) {
                    if (response.authResponse) {
                        console.log('Logged in');
                        facebookSend();
                    } else {
                        console.log('Not logged in');
                    }
                });
            }
        });

    });
    var facebookSend = function() {
        console.log('facebookSend started');
        FB.ui({ 
            method: 'feed',
            display: 'iframe',
            link: '*PAGE_LINK*'
        });
    }
</script>
4

0 回答 0