0

我使用以下代码获取 Facebook 分享按钮、Facebook 赞、Facebook 发送和 Google +1:

    <div id="fb-root"></div>
    <script>(function(d, s, id) {
      var js, fjs = d.getElementsByTagName(s)[0];
      if (d.getElementById(id)) return;
      js = d.createElement(s); js.id = id;
      js.src = "//connect.facebook.net/ar_AR/all.js#xfbml=1&appId=<?php echo Configure::read('FBappId');?>";
      fjs.parentNode.insertBefore(js, fjs);
    }(document, 'script', 'facebook-jssdk'));
    </script>

<!-- FaceBook SHARE BUTTON HERE -->
    <a name="fb_share"></a>
<!-- End FACEBOOK SHARE -->
    <div class="fb-send" data-href="<?php echo $URL;?>" data-font="tahoma"></div>

    <script src="http://static.ak.fbcdn.net/connect.php/js/FB.Share" 
            type="text/javascript">
    </script>
    <div class="fb-like" data-send="false" data-layout="button_count" data-width="" data-show-faces="false" data-font="tahoma"></div>
    <span>
    <!-- Place this tag where you want the +1 button to render -->
    <g:plusone size="medium"></g:plusone>

    <!-- Place this render call where appropriate -->
    <script type="text/javascript">
      window.___gcfg = {lang: 'ar'};

      (function() {
        var po = document.createElement('script'); po.type = 'text/javascript'; po.async = true;
        po.src = 'https://apis.google.com/js/plusone.js';
        var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(po, s);
      })();
    </script>
    </span>

问题是Facebook 分享按钮在宽度和高度为 1000 像素的 iframe 中呈现,并且呈现超出预期的视图范围。下面的屏幕截图会解释得更清楚: 在此处输入图像描述 顺便说一句:文档是 RTL 方向,分享按钮应该放在其他按钮旁边。屏幕截图是使用 FireFox 18.0 拍摄的。

4

3 回答 3

1

<fb:share-button type="box_count"></fb:share-button>仅在要显示共享按钮的地方使用此选项。

于 2013-01-16T18:33:13.657 回答
0

两天前我的“使用 Facebook 登录”按钮也发生了同样的事情,不确定这是否是 FB 的错误?

无论如何,我已经使用 CSS hack 来修复它......不理想!

.fb_iframe_widget iframe{width:auto!important; height:auto!important}
于 2013-01-17T20:01:18.257 回答
0

此问题的最终解决方案在以下链接中进行了演示。基本上,这取决于在 Facebook 上创建指向 sharer.php 的直接链接。当然,我删除了RohitKumarChoudhary答案中所认为的额外 Javascipt 链接标签。如下:

<div class="socials">
<div id="fb-root"></div>
<script>(function(d, s, id) {
  var js, fjs = d.getElementsByTagName(s)[0];
  if (d.getElementById(id)) return;
  js = d.createElement(s); js.id = id;
  js.src = "//connect.facebook.net/ar_AR/all.js#xfbml=1&appId=xxxxxxxxxx";
  fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));</script>
<div class="fb-send" data-href="http://quran.2index.net/viewAyah/1933" data-font="tahoma"></div>
<!--<a name="fb_share"></a>--> 
<a href="http://www.facebook.com/sharer.php?app_id=xxxxxxxxxx&sdk=joey&u=http://quran.2index.net/viewAyah/1933&display=popup" target="_blank"><img src="/img/../images/facebook16.png" alt="" />مشاركة</a>


<div class="fb-like" data-send="false" data-layout="button_count" data-width="" data-show-faces="false" data-font="tahoma"></div>
....
</div>
于 2013-01-20T13:09:33.500 回答