次の HTML と JavaScript があります。3 つの写真と 3 つのリンクがあります。1 つのリンクをクリックすると、1 つの画像が表示され、他の 2 つは非表示になります。
display: none
CSS に が存在しない場合、これは正常に機能します。しかし、最初は写真が表示されないdisplay: none
ようにしたいので、そこに置きました。今、リンクをクリックしても写真が表示されません。何故ですか?
HTML
<div id="content">
<div id="left">
<a href="javascript:showImage('img1')">show image1</a>
<a href="javascript:showImage('img2')">show image2</a>
<a href="javascript:showImage('img3')">show image3</a>
</div>
<div id="right">
<img id="img1" src="berlin.jpg" height="200px"/>
<img id="img2" src="london.jpg" height="200px"/>
<img id="img3" src="madrid.jpg" height="200px"/>
</div>
</div>
JavaScript
function showImage(id) {
var images_id = new Array("img1", "img2", "img3");
for (var i = 0; i < images_id.length; i++) {
setImageVisible(images_id[i], false);
}
setImageVisible(id, true);
}
function setImageVisible(id, visible) {
var img = document.getElementById(id);
img.style.display = (visible ? '' : 'none');
}
CSS
#img1, #img2, #img3 {
display: none;
}