6

我想根据 javascript 变量动态更改下面的 fb 评论插件的 data-href。我正在运行一个 flash swf 文件,并通过一个 javascript 函数将 data-href 的新链接传递到 html 包装器中。当我这样做时,我希望 fb 评论插件刷新到新的 data-href 链接。

<div style="float: left; padding-left:5px; min-height:500px" class="fb-comments" data-href="www.example.com" data-num-posts="20" data-width="380"></div>

调用 javascript 函数传入评论插件的新链接:

function changeCommentsUrl(newUrl){
// should refresh fb comments plugin for the "newUrl" variable
}
4

2 回答 2

12

这将加载初始评论框,脚本将在执行时清除评论 div 包装器并用新的 url 替换 html5 评论框。然后 JS SDK 将解析新框。

这项工作需要 JS SDK。参考https://developers.facebook.com/docs/reference/javascript/

修复来自 dom 操作的 xfbml 渲染


<div id="comments">
<div style="float: left; padding-left:5px; min-height:500px" class="fb-comments" data-href="www.example.com" data-num-posts="20" data-width="380"></div>
</div>
<script>
function changeCommentsUrl(newUrl){
// should refresh fb comments plugin for the "newUrl" variable
document.getElementById('comments').innerHTML='';
parser=document.getElementById('comments');
parser.innerHTML='<div style="float: left; padding-left:5px; min-height:500px" class="fb-comments" data-href="'+newUrl+'" data-num-posts="20" data-width="380"></div>';
FB.XFBML.parse(parser);
}
</script>

用户解决:

document.getElementById('comments').innerHTML='<div style="float: left; padding-left:5px; min-height:500px" class="fb-comments" data-href="'+link+'" data-num-posts="20" data-width="380"></div>'; 
FB.XFBML.parse(document.getElementById('comments'));

于 2012-06-20T15:26:32.600 回答
2

我找到了让你的 Facebook 评论框识别每个页面的单个 URL 的最简单有效的方法(特别适用于电子商务网站)。

将此脚本添加到网站模板的顶部标题部分(它会为您的评论框 div 生成 de data-href 值:

<script type="text/javascript" language="javascript">
  jQuery("#FC").attr("data-href", window.location.href.split("?")[0]); 
</script>

然后在您的评论框 div 上,为 javascript 上生成的值添加 id:

<div id="FC" class="fb-comments" data-href="" data-width="700" data-numposts="5" data-colorscheme="light">

瞧。我花了这么多时间来破解这个坚果,我只需要分享给你,以节省一些休息时间!干杯!

于 2015-07-07T09:30:36.030 回答