To put a delay on a menu onmouseover effect, setTimeout is one of the options. But when I try it, the function isn’t called.
HTML:
<li><a href="#"
onmouseover="mopendelay('menu_proj')"
<li>
JavaScript:
// open hidden layer
function mopen(id)
{
// cancel close timer
mcancelclosetime();
// close old layer
if(ddmenuitem) ddmenuitem.style.visibility = 'hidden';
// get new layer and show it
ddmenuitem = document.getElementById(id);
ddmenuitem.style.visibility = 'visible';
}
// delay menu open on mouseover
function mopendelay(id)
{
var delay = setTimeout(function(){
alert('delay'); // isn't called
mopen(id);
}, 200);
clearTimeout(delay);
}
You’re clearing timeout before the timeout function can execute.