Jump to content

Recommended Posts

Hi all, I am relatively new to javascript, hence the basic problem! All I am trying to do is show a different image for a button onmouseover, basically it just has an arrow to show the button is selected.

 

Here is my code

<script type="text/javascript">
function mouseOver()
{
document.getElementById("home").src ="images/homebuttonselected.gif";
document.getElementById("packages").src ="images/packagebuttonselected.gif";
}

function mouseOut()
{
document.getElementById("home").src ="images/homebutton.gif";
document.getElementById("packages").src ="images/packagebutton.gif";
}
</script>
</head>

<body>
<div id="main">
<div id="links"><img src="images/homebutton.gif" class="buttons" id="home" onmouseover="mouseOver()" onmouseout="mouseOut()" />
<img src="images/packagebutton.gif" class="buttons" id="packages" onmouseover="mouseOver()" onmouseout="mouseOut()" /></div>
</div>
</body>
</html>

 

My problem is that when one button is highlighted, both images change to there onmouseover state, how to I remedy this so each one is treated individually?

 

Thanks

 

Link to comment
https://forums.phpfreaks.com/topic/226256-onmouseover-help/
Share on other sites

Ok I have noticed I can do it like this:

<script type="text/javascript">
function homeOver()
{
document.getElementById("home").src ="images/homebuttonselected.gif";

}

function homeOut()
{
document.getElementById("home").src ="images/homebutton.gif";

}

function packageOver()
{

document.getElementById("packages").src ="images/packagebuttonselected.gif";
}

function packageOut()
{

document.getElementById("packages").src ="images/packagebutton.gif";
}

function purchaseOver()
{

document.getElementById("purchase").src ="images/purchasebuttonselected.gif";
}

function purchaseOut()
{

document.getElementById("purchase").src ="images/purchasebutton.gif";
}

</script>
</head>

<body>
<div id="main">
<div id="links">
<img src="images/homebutton.gif" class="buttons" id="home" onmouseover="homeOver()" onmouseout="homeOut()" />

<img src="images/packagebutton.gif" class="buttons" id="packages" onmouseover="packageOver()" onmouseout="packageOut()" />

<img src="images/purchasebutton.gif" class="buttons" id="purchase" onmouseover="purchaseOver()" onmouseout="purchaseOut()" /></div>
</div>
</body>
</html>

 

But is their a simpler way?

 

Link to comment
https://forums.phpfreaks.com/topic/226256-onmouseover-help/#findComment-1167963
Share on other sites

looks like everything is mostly consistently named, so you can reduce it to this:

 

function swapImages(that) {
  that.src =  (that.src.indexOf('buttonselected')>-1) ? ("images/"+that.id+"button.gif") : ("images/"+that.id+"buttonselected.gif");
}

<img src="images/homebutton.gif" class="buttons" id="home" onmouseover="swapImages(this)" onmouseout="swapImages(this)" />

<img src="images/packagebutton.gif" class="buttons" id="packages" onmouseover="swapImages(this)" onmouseout="swapImages(this)" />

<img src="images/purchasebutton.gif" class="buttons" id="purchase" onmouseover="swapImages(this)" onmouseout="swapImages(this)" />

 

only thing is that you need to make your id="..." match your image prefix.  Some of them don't match.  Like id="package" vs. "packagesbuttonselected.gif".  Need to either change your id to "packages" or rename your .gif to "packagebuttonselected.gif"

Link to comment
https://forums.phpfreaks.com/topic/226256-onmouseover-help/#findComment-1167986
Share on other sites

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.