有没有办法通过js动态添加谷歌+1按钮?我需要它,因为一个页面有许多 URL 可以共享,并且它们是通过 AJAX 获得的。因此,当我获得所需的 URL 时,我想在页面的某些位置生成“+1”-s。
我编写了可在除 IE8 之外的所有浏览器中运行的测试代码(谷歌根本不支持 IE7):
<div class="googlePlusBtn"></div>
<a href="#" class="addGooglePlus">Click me!</a>
<script type="text/javascript">
jQuery(function(){
jQuery('.googlePlusBtn').html('<g:plusone annotation="inline"></g:plusone>');
jQuery('a.addGooglePlus').click(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);
return false;
})
})
</script>
请你帮助我好吗?
UPD:已修复。解决方案如下:
<div id="googlePlusBtn"></div>
<a href="#" class="addGooglePlus">Click me!</a>
<script type="text/javascript">
jQuery(function(){
var po = document.createElement('g:plusone');
var s = document.getElementById('googlePlusBtn');
s.appendChild(po);
jQuery('a.addGooglePlus').click(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);
return false;
})
})
</script>
因此,只需将创建文档方法从 jQuery 更改为干净的 Javascript。IE8 与它一起工作!