0

次の HTML と JavaScript があります。3 つの写真と 3 つのリンクがあります。1 つのリンクをクリックすると、1 つの画像が表示され、他の 2 つは非表示になります。

これは機能します。ただし、画像が表示されたときに、ページのどこかに押し込まれるのではなく、他の2つの画像が存在しないかのように表示されるようにしたいと思います。それは可能ですか?

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.visibility = (visible ? 'visible' : 'hidden');
}
4

1 に答える 1

3

これの代わりに:

img.style.visibility = (visible ? 'visible' : 'hidden');

これを使って:

img.style.display = (visible ? '' : 'none');
于 2013-03-10T04:02:54.253 に答える