[英]How to dynamically change facebook comments plugin url based on javascript variable?
我想基于javascript变量动态更改下面的fb评论插件的data-href。 我正在运行一个flash swf文件,并通过javascript函数将data-href的新链接传递给html包装器。 当我这样做时,我希望fb comments插件刷新到新的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
}
这将加载初始注释框,脚本将在执行时清除注释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'));
我发现了一种最简单有效的方法,可以让你的Facebook评论框识别每个页面的个别网址(特别适合电子商务网站)。
将此脚本添加到网站模板的顶部标题部分(它会为您的评论框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">
瞧。 我花了很多时间来破解这个坚果,我只需要为你分享它,以节省休息时间! 干杯!
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.