zoukankan      html  css  js  c++  java
  • JQuery mouseover mouseout && mouseenter mouseleave 的区别

    用交互操作中,经常需要知道用户操作鼠标是否有移到元素内部或是元素外部,因此jQuery提供了一个mouseenter和mouseleave的快捷方法可以监听用户移动到内部的操作

    使用上非常简单,三种参数传递方式与mouseover和mouseout是一模一样的,所以这里不再重复,主要讲讲区别,下面以mouseenter为例:

    mouseenter JavaScript事件是Internet Explorer专有的。由于该事件在平时很有用,jQuery的模拟这一事件,以便它可用于所有浏览器。该事件在鼠标移入到元素上时被触发。任何HTML元素都可以接受此事件。

    mouseenter事件和mouseover的区别 

    关键点就是:冒泡的方式处理问题

    简单的例子:

    mouseover为例:

    <div class="aaron2">
        <p>鼠标离开此区域触发mouseleave事件</p>
    </div>

    如果在p元素与div元素都绑定mouseover事件,鼠标在离开p元素,但是没有离开div元素的时候,触发的结果:

    1. p元素响应事件
    2. div元素响应事件

    这里的问题是div为什么会被触发? 原因就是事件冒泡的问题,p元素触发了mouseover,他会一直往上找父元素上的mouseover事件,如果父元素有mouseover事件就会被触发

    所以在这种情况下面,jQuery推荐我们使用 mouseenter事件

    mouseenter事件只会在绑定它的元素上被调用,而不会在后代节点上被触发。

    参考 https://www.cnblogs.com/wymbk/p/5711715.html
    
    
    <!DOCTYPE html>
    <html>
    
    <head>
        <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
        <title></title>
        <style>
        .left div,
        .right div {
             350px;
            height: 150px;
            padding: 5px;
            margin: 5px;
            border: 1px solid #ccc;
        }
        p{
            height: 50px;
            border: 1px solid red;
            margin: 30px;
        }
        .left div {
            background: #bbffaa;
        }
        .right div {
            background: yellow;
        }
        </style>
        <script src="jquery-3.3.1.js"></script>
    </head>
    
    <body>
        <h2>.mouseover()方法</h2>
        <div class="left">
            <div class="aaron1">
                <p>鼠标离开此区域触发mouseover事件</p>
                <a>mouseover事件触发次数:</a><br/>
                <a>mouseover冒泡事件触发次数:</a>
            </div>
        </div>
    
        <h2>.mouseenter()方法</h2>
        <div class="right">
            <div class="aaron2">
                <p>鼠标进入此区域触发mouseenter事件</p>
                <a>mouseenter事件触发次数:</a><br/>
                <a>mouseenter冒泡事件触发次数:</a>
            </div>
        </div>
        <br/>
       
        
        <script type="text/javascript">
    
            var i = 0;
            $(".aaron1 p").mouseover(function(e) {
                $(".aaron1 a:first").html('mouseover事件触发次数:' + (++i))
            })
    
            var n = 0;
            $(".aaron1").mouseover(function() {
                $(".aaron1 a:last").html('mouseover冒泡事件触发次数:' + (++n))
            })
    
    
        </script>
    
    
        <script type="text/javascript">
    
            var i = 0;
            $(".aaron2 p").mouseenter(function(e) {
                $(".aaron2 a:first").html('mouseenter事件触发次数:' + (++i))
            })
    
            var n = 0;
            $(".aaron2").mouseenter(function() {
                $(".aaron2 a:last").html('mouseenter冒泡事件触发次数:' + (++n))
            })
    
        </script>
    
    
    </body>
    
    </html>
    
    
    

      

     
  • 相关阅读:
    C++ 设计模式 —— 訪问者(Visitor)
    图解IIS配置过程
    JSBridge
    10大H5前端框架,让你开发不愁
    具体解释java中的volatilekeyword
    网速变慢解决方法.Tracert与PathPing(转)
    最快下载速度100Mbps!4G LTE技术全解析
    Windows客户端的JProfiler远程监控Linux上的Tomcat
    Java内存泄露原因详解
    JProfiler 解决 Java 服务器的性能跟踪
  • 原文地址:https://www.cnblogs.com/potato-lee/p/8940108.html
Copyright © 2011-2022 走看看