请找到代码并提出建议。
我正在尝试添加另一张图片(' correct10.png')onClick显示图片的事件,即Van.png'。但没有任何事情发生,所以请建议。
这里是html:
<!DOCTYPE html >
<html lang="en">
<head>
<title>Adding Another Image onClick</title>
<script>
function doImgSwap()
{
document.getElementById('newImg').addEventListener('click', function(e){
var img = document.createElement('img');
img.setAttribute('src','correct10.png');
e.target.appendChild(img);
});
}
</script>
</head>
<body>
<p><a href="#" id="newImg" onClick="doImgSwap()"><img src="van.png"></a></p>
</body>
</html>
答案 0 :(得分:0)
您的代码应为
<!DOCTYPE html>
<html lang="en">
<head>
<title>Adding Another Image onClick</title>
<script>
window.onload = function() {
document.getElementById('newImg').addEventListener('click', function(e) {
var img = document.createElement('img');
img.setAttribute('src', 'correct10.png');
this.appendChild(img);
});
}
</script>
</head>
<body>
<p>
<a href="#" id="newImg">
<img src="van.png"/>
</a>
</p>
</body>
</html>
答案 1 :(得分:0)
首先将js文件放在你的html下,或者使用window.onload函数来确保
<!DOCTYPE html >
<html lang="en">
<head>
<title>Adding Another Image onClick</title>
</head>
<body>
<p><a href="#" id="newImg" onClick="doImgSwap()"><img src="van.png"></a></p>
<script>
function doImgSwap()
{
document.getElementById('newImg').addEventListener('click', function(e){
var img = document.createElement('img');
img.setAttribute('src','correct10.png');
e.target.appendChild(img);
});
}
</script>
</body>
</html>
答案 2 :(得分:0)
您的doImgSwap
方法会创建一个事件处理程序,它实际上不会交换图像。
应该是:
function doImgSwap(el){
var img = document.createElement('img');
img.setAttribute('src','correct10.png');
el.appendChild(img);
}
你必须传递onClick
属性中的元素,就像这样
onClick="doImgSwap(this)"