0

我想使用 javascript 创建一个 iframe,然后将其插入到两个具有 id“fblike”的部门中。我尝试使用以下代码,但它不起作用。

<script type="text/javascript">
  (function(){
    var fb = document.createElement('iframe');
    fb.src = 'http://www.facebook.com/plugins/like.php?href='+encodeURIComponent(location.href)+'&amp;locale=en_US&amp;send=false&amp;layout=button_count&amp;width=90&amp;show_faces=false&amp;action=like&amp;colorscheme=light&amp;font=verdana&amp;height=21';
    fb.scrolling = 'no';
    fb.frameborder = '0';
    fb.style = 'border:none; overflow:hidden; width:90px; height:21px;';
    fb.allowTransparency = 'none';
    document.getElementsById('fblike')[0].appendChild(fb);
  })();
</script>

我知道代码中一定有一些错误,因为我对 javascript 知之甚少。任何人请帮助我!谢谢

更新:感谢您的帮助 :) 我更新了代码以消除错误。现在以下代码适用于我:

<script type="text/javascript"> 
  (function(){
    var fb = document.createElement('iframe');
    fb.src = 'http://www.facebook.com/plugins/like.php?href='+encodeURIComponent(location.href)+'&locale=en_US&send=false&layout=button_count&width=90&show_faces=false&action=like&colorscheme=light&font=verdana&height=21';
    fb.style.cssText = 'border:none; overflow:hidden; width:90px; height:21px;';
    fb.frameBorder = '0';
    fb.scrolling = 'no';
    fb.allowTransparency = 'true';
    document.getElementById('fbabove').appendChild(fb.cloneNode(true));
    document.getElementById('fbbelow').appendChild(fb.cloneNode(true));
  })();
</script>
4

4 回答 4

2

您不应该id在同一页面上有具有相同值的属性。首先修复它,否则document.getElementById()永远不会正常工作(它只返回一个元素)并且document.getElementsById()(带有s)不存在。

于 2011-12-01T02:50:35.520 回答
1

调用该函数document.getElementById并返回一个元素,因为您永远不能拥有多个具有相同 id 的元素

所以改变

document.getElementsById('fblike')[0].appendChild(fb);

document.getElementById('fblike').appendChild(fb);
于 2011-12-01T02:50:05.733 回答
1

首先,你有一个类型。它getElementById,因为在任何给定页面上只有一个元素可以有一个 ID。

其次,因为只有一个,所以不需要[0].

document.getElementById('fblike').appendChild(fb);

但是,否则,我们需要更多详细信息来了解这是否是您遇到的唯一问题。

于 2011-12-01T02:50:48.790 回答
0

实际上,您想将两个 iframe 插入到两个 div 中,对吗?这是可以执行您想要的代码的代码(不能声称它是最佳的,因为您有重复的 id - 正如上面的人所说,如果可能的话,您最好制作两个不同的 id):

<script type="text/javascript">
  (function(){
    var list = document.getElementsByTagName('div'), i, fb;
    for (i = 0; i < list.length; i++) {
        if (list[i].id == 'fblike') {
            fb = document.createElement('iframe');
            fb.src = 'http://www.facebook.com/plugins/like.php?href='+encodeURIComponent(location.href)+'&amp;locale=en_US&amp;send=false&amp;layout=button_count&amp;width=90&amp;show_faces=false&amp;action=like&amp;colorscheme=light&amp;font=verdana&amp;height=21';
            fb.scrolling = 'no';
            fb.frameborder = '0';
            fb.style = 'border:none; overflow:hidden; width:90px; height:21px;';
            fb.allowTransparency = 'none';
            list[i].appendChild(fb);
        }
    }
  })();
</script>
于 2011-12-01T03:04:08.447 回答