鼠标悬停问题
我有一个调用 onmouseover javascript 函数的链接,该函数使其下面的 div 可见。现在这一切都有效了。
现在的问题是我有一个 href 链接,当我将鼠标悬停在它的顶部时,它工作得很好,但是当我将鼠标移到“现在可见”div 上方时,它会闪烁,因为 html 似乎认为它没有离开 div然后再次打开它,这样它就会不断地关闭和打开。
我怎样才能阻止这种情况发生呢? (下面的 html,javascript 是一个简单的函数,使其可见,没有必要发布,它可以工作)
<a style="text-decoration:none;display:block;" onmouseout="ShowStock(1,0);" onmouseover="ShowStock(1,1);" href="">50</a>
<div id="stock1" style="visibility: hidden;">
<a style=" background-color:#009933; text-align:center;" name="1">1</a>
</div>
I have a a link that calls a onmouseover javascript function that makes a div below it visible. Now this all works.
Now the problem is I have a a href link and when I mouse over the top part of it, it works perfectly but when I move my mouse overtop of the "now visible" div it blinks because html seems to think it is not off the div and then on it again so it keeps turning it off and on.
How could I stop this from happening? (html below, javascript is a simple function to make it visible, no point in posting, it works)
<a style="text-decoration:none;display:block;" onmouseout="ShowStock(1,0);" onmouseover="ShowStock(1,1);" href="">50</a>
<div id="stock1" style="visibility: hidden;">
<a style=" background-color:#009933; text-align:center;" name="1">1</a>
</div>
VIDEO OF IT HAPPENING: http://screencast.com/t/qjxHN4wyIc
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
视频中演示的问题是 stock1 div 正在窃取焦点,然后触发 onmouseout,关闭 stock1 div,然后触发 A 标签的 onmouseover,显示 stock1 div,然后窃取焦点,触发 onmouseout A 标签等...
最简单的方法是将相同的 ShowStock onmouseout/onmouseover 也应用于 stock1 div,这样它在鼠标悬停时“显示”自身,但在鼠标未悬停时隐藏自己,除非您将鼠标悬停在显示它的 A 标记内的区域上。
例如,这可以完美地工作(在 jsfiddle.net 上,它还演示了一个单独的版本视频中演示的错误):
The problem demonstrated in your video is that the stock1 div is stealing focus, which is then firing the onmouseout, closing the stock1 div, which then fires the onmouseover of the A tag, shows the stock1 div, which then steals focus, fires onmouseout of the A tag, etc...
The easiest thing to do is apply the same ShowStock onmouseout/onmouseover to the stock1 div as well, so that it "shows" itself while moused over, but hides itself when not moused over, except when you mouse over an area within the A tag that shows it.
For instance, this works perfectly (on jsfiddle.net, which also demonstrates a separate version with the error demonstrated in video):
尝试将 onmouseout 事件放在 stock Outsider 元素上,就像在具有 onmousein 事件的元素“a”上一样,并删除原始元素的 onmouseout 事件。
这样,当您将鼠标移出刚刚出现的库存元素时,它就会关闭。
Try to put the onmouseout event on the stock outsider element just the same way it is on the element "a" that has the onmousein event, and remove the onmouseout event of the original element.
This way it will just close when you get the mouse out of the stock element that has just appeared.