javascript - #xfbml=1 导致问题

标签 javascript facebook fbml xfbml

我的网站上有两种不同的机制,同时使用 xfbml 和 fbjs:

  • 单个条目的 FB:Like 标签
  • 使用 fb connect 登录 facebook 的 FB 对象

我的问题是,当我在页面上包含“all.js”时,登录脚本可以工作,但 fb:like 标记不起作用。

当我包含“all.js#xfbml=1”时,fb:like 标记再次工作,但现在我的 FB 对象未定义,并且我的登录代码不起作用。

我有什么遗漏吗?

预先感谢您提供的任何帮助。

最佳答案

您只需包含一次脚本引用,并在页面加载时调用脚本的 init 即可。您可以将其用于 fb:like 按钮或登录脚本。

<div id="fb-root"></div>
<script src="http://connect.facebook.net/en_US/all.js"></script>
<script>
  FB.init({
    appId  : 'YOUR APP ID',
    status : true, // check login status
    cookie : true, // enable cookies to allow the server to access the session
    xfbml  : true  // parse XFBML
  });
</script>

关键是将 xfbml 设置为 true(这就是 #xfbml=1 的作用)。如果您没有进行该设置,则类似按钮将不会呈现。

如果您想订阅登录事件,只需在 FB.init() 调用后添加以下脚本:

  FB.Event.subscribe('auth.login', function(response) {
    window.location.reload(); // or something else...
  });

这里是您的登录脚本,仅当用户单击链接、按钮等时才会触发。

function doLogin() {
   FB.login(function(response) {
     if (response.session) {
       if (response.perms) {
         // user is logged in and granted some permissions.
         // perms is a comma separated list of granted permissions
       } else {
         // user is logged in, but did not grant any permissions
       }
     } else {
       // user is not logged in
     }
   }, {perms:'read_stream,publish_stream,offline_access'});
}

关于javascript - #xfbml=1 导致问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4695744/

相关文章:

facebook - 我应该在 head 标签中添加什么

php - 为我网站上的任意元素创建 "Like"按钮,并读回状态 - 可能吗?

php - 使用 PHP、AJAX 和 MySQL 检查更新的最快方法

javascript - 选择 html 元素 1,2,5,6 ...元素数量未知的优雅方法/

ios - 是否可以访问 Facebook 当前的热门话题?

Android Facebook sdk 分享到用户墙上

javascript - MoxieManager TinyMCE 集成

javascript - 为什么对象在 Chrome DevTools 中不存在?

javascript - Facebook FBML 问题

facebook - 如何发送链接到外部网站的 Facebook 请求?