0

我试图让一个非常简单的 Javascript 函数工作,它将使用 .removeChild 和 .appendChild 将一个图像更改为另一个图像。我的代码如下:

<html> 
<head> 
<script type="text/javascript" language="javascript"> 
function bannerload(){

var banner = new Image();
banner.src = "IMG/banner.gif";

var loading = new Image();
loading.src = "IMG/loading.gif";

var bannerElement = document.getElementById("BANNER");

bannerElement.removeChild(banner);
bannerElement.appendChild(loading);
}
</script> 
</head> 

<body onload="bannerload()"> 
<div id="BANNER">
<img src="IMG/banner.gif" alt="Banner" />
</div> 
</body> 
</html>

但是,它不起作用。该页面只加载了banner.gif,并且此图像永远不会更改为loading.gif。我不知道为什么,请帮忙?!

谢谢!

4

2 回答 2

2

这不起作用的原因是您试图添加一个孩子并删除一个不是孩子的孩子。

您正试图从名为 BANNER 的元素中删除名为 BANNER 的子元素。

显然,名为 BANNER 的元素没有名为 Banner 的子元素。您有两种选择,要么将 id 赋予子元素并调用 `banner.parent.removeChild(banner) 或以下:

示例片段

var bannerElement = document.getElementById("BANNER");
//Banner only has one child.
var child = bannerElement.children[0];

bannerElement.removeChild(child);
bannerElement.appendChild(loading);
于 2011-05-12T20:37:01.817 回答
0

我认为您的问题是您正在尝试删除bannerElement 中不存在的孩子。

var banner = new Image();
banner.src = "IMG/banner.gif";
...
bannerElement.removeChild(banner);

看看你是如何制作一个新图像然后删除它的,即使你还没有附加它?我认为你应该尝试这样的事情:

var banner = document.getElementById('id_banner')
banner.src = 'IMG/banner.gif' // or 'IMG/loading.gif' depending on which one you want
...
<body onload="bannerload()"> 
    <div id="BANNER">
        <img id="id_banner" src="IMG/banner.gif" alt="Banner" />
...
于 2011-05-12T20:38:48.443 回答