加载中...

mouseover()


概述    .mouseover( handler(eventObject) )

返回值:jQuery

描述:为 JavaScript 的 "mouseover" 事件绑定一个处理函数,或者触发元素上的该事件。(手册网注:支持事件冒泡)

  • V : 1.0.mouseover( handler(eventObject) )

    • handler(eventObject)
      类型: Function()
      每次事件触发时会执行的函数。
  • V : 1.4.3.mouseover( [eventData ], handler(eventObject) )

    • eventData
      类型: PlainObject
      一个对象,它包含的数据键值对映射将被传递给事件处理程序。
    • handler(eventObject)
      类型: Function()
      每次事件触发时会执行的函数。
  • V : 1.0.mouseover()

    • 这个方法不接受任何参数。

这个方法的前两个用法是 .bind('mouseover', handler) 的快捷方式,第3个不带参数的用法是 .trigger('mouseover') 的快捷方式。

当鼠标指针进入元素内时,mouseover事件就会被触发,任何HTML元素都可以接受此事件。

举例来说,请看下面的HTML:

  1. <div id="outer">
  2. Outer
  3. <div id="inner">
  4. Inner
  5. </div>
  6. </div>
  7. <div id="other">
  8. Trigger the handler
  9. </div>
  10. <div id="log"></div>
图1 - 渲染后的HTML插图

这个事件可以绑定到任何元素:

  1. $('#outer').mouseover(function() {
  2. $('#log').append('<div>Handler for .mouseover() called.</div>');
  3. });

现在当指针进入Outer <div>元素时,“Handler for .mousedown() called.”这个字符串将被添加到<div id="log">。我们也可以通过点击其它元素,手动触发另一个元素上的该事件:

  1. $('#other').click(function() {
  2. $('#outer').mouseover();
  3. });

这些代码执行后,点击Trigger the handler 同样添加这个信息。

由于此事件类型冒泡,可能导致引起的很多头痛的问题。例如,在这个示例中当鼠标指针移出Inner元素,mouseover事件将被发送到Inner元素,然后冒泡到Outer元素 。这可能会不合时宜的触发绑定的mouseover处理函数。这可以用一个替代方法,见讨论. mouseenter ()

Additional Notes(其他注意事项):

  • .mouseover()方法只是作为.on( "mouseover", handler )的一个速记写法,移除该事件可以使用.off( "mouseover" )

示例

当触发 mouseover 和 mouseenter 事件时,显示鼠标移出对象的次数。当鼠标移入绑定 mouseover 事件元素的子元素时,mouseover 事件同样会被触发。但是,只有在绑定 mouseenter 事件的元素上,将鼠标移入时,才会触发该事件。

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. div.out { width:40%; height:120px; margin:0 15px;
  6. background-color:#D6EDFC; float:left; }
  7. div.in { width:60%; height:60%;
  8. background-color:#FFCC00; margin:10px auto; }
  9. p { line-height:1em; margin:0; padding:0; }
  10. </style>
  11. <script src="http://code.jquery.com/jquery-latest.js"></script>
  12. </head>
  13. <body>
  14. <div class="out overout">
  15. <span>move your mouse</span>
  16. <div class="in">
  17. </div>
  18. </div>
  19. <div class="out enterleave">
  20. <span>move your mouse</span>
  21. <div class="in">
  22. </div>
  23. </div>
  24. <script>
  25. var i = 0;
  26. $("div.overout").mouseover(function() {
  27. i += 1;
  28. $(this).find("span").text( "mouse over x " + i );
  29. }).mouseout(function(){
  30. $(this).find("span").text("mouse out ");
  31. });
  32. var n = 0;
  33. $("div.enterleave").mouseenter(function() {
  34. n += 1;
  35. $(this).find("span").text( "mouse enter x " + n );
  36. }).mouseleave(function() {
  37. $(this).find("span").text("mouse leave");
  38. });
  39. </script>
  40. </body>
  41. </html>

运行一下


还没有评论.