加载中...

mouseleave()


概述    .mouseleave( handler(eventObject) )

返回值:jQuery

描述:为 mouse leaves(鼠标离开) 事件绑定一个处理函数,或者触发元素上的 mouse leaves(鼠标离开) 事件。

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

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

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

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

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

mouseleaveJavaScript事件是Internet Explorer专有的。。由于该事件在平时很有用,jQuery的模拟这一事件,以便它可用于所有浏览器。该事件在鼠标离开元素上时被触发。任何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').mouseleave(function() {
  2. $('#log').append('<div>Handler for .mouseleave() called.</div>');
  3. });

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

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

这些代码执行后,点击Trigger the handler同样警报显示。

mouseleave事件和mouseover的不同之处是事件的冒泡的方式。如果mouseover在这个示例中使用了,然后当鼠标指针在Inner元素上移出,该处理程序将被触发。这通常是不受欢迎的行为。另一方面, mouseleave 事件只会在绑定它的元素上被调用,而不会在后代节点上被触发。因此,在这个示例中,当鼠标离开Outer元素,而不是Inner元素时,处理器才会被触发。

Additional Notes(其他注意事项):

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

示例

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

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

运行一下


还没有评论.