zoukankan      html  css  js  c++  java
  • Day4-JS-JavaScript HTML DOM EventListener

    一、addEventListener() 方法

    (先上实例)

        <button id="btn">点我</button>
        <p id="demo"></p>
    
        <script>
            document.getElementById("btn").addEventListener("click",displayDate);
            function displayDate(){
                document.getElementById("demo").innerHTML=Date();
            }
        </script>

    addEventListener() 方法用于向指定元素添加事件句柄

    addEventListener() 方法添加的事件句柄不会覆盖已存在的事件句柄

    ====小技巧:可以使用 removeEventListener() 方法来移除事件的监听

    二、向原元素添加事件句柄

      ①实例1:(可以直接在内部对函数进行定义)

        <p>该实例使用 addEventListener() 方法在按钮中添加点击事件。 </p>
    <button id="myBtn">点我</button>
    <script>
        document.getElementById("myBtn").addEventListener("click",function(){
            alert("hahahhzy!");
        })
    </script>

    三、向同一个元素中添加多个事件句柄

      ===addEventListener() 方法允许向同一个元素添加多个事件,且不会覆盖已存在的事件

    <button id="Btn">点我</button>
        <p id="demo"></p>
    
        <script>
            document.getElementById("Btn").addEventListener("click",myFunction1);
            document.getElementById("Btn").addEventListener("click",myFunction2);
            function myFunction1(){
                alert("1");
            }
            function myFunction2(){
                alert("2");
            }
        </script>

    ====可以向同个元素添加不同类型的事件

    四、向 Window 对象添加事件句柄

    实例1:当用户重置窗口大小时添加事件监听,这就是对resize进行重置事件监听了

    (这个打开的时候,是不会看到数字的,要缩放一下页面触发了我们定义的事件,才可以看到任意产生的数字的)

      <p>实例在 window 对象中使用 addEventListener() 方法。</p>
    <p>尝试重置浏览器的窗口触发 "resize" 事件句柄。</p>
    <p id="demo"></p>
    
    <script>
        window.addEventListener("resize",function(){
            document.getElementById("demo").innerHTML=Math.random();
        })
    </script>

    五、给添加时间句柄 传递参数

    ===当传递参数值时,使用"匿名函数"调用带参数的函数

      <p>实例演示了在使用 addEventListener() 方法时如何传递参数。</p>
    <p>点击按钮执行计算。</p>
    <button id="myBtn">点我</button>
    <p id="demo"></p>
    <script>
        var p1=5;
        var p2=7;
        document.getElementById("myBtn").addEventListener("click",function(){
            myFunction(p1,p2);
        });
        function myFunction(a,b){
            var result=a*b;
            document.getElementById("demo").innerHTML=result;
        }
    </script>

    六、事件冒泡或事件捕获

    哪个元素的 "click" 事件先被触发呢?冒泡的话就是内部的事件会想被触发的,捕获的话就是外部的元素先被触发

    addEventListener() 方法可以指定 "useCapture" 参数来设置传递类型:

    默认值为 false, 即冒泡传递,当值为 true 时, 事件使用捕获传递

    addEventListener(event, function, useCapture);

    七、removeEventListener() 方法

    removeEventListener() 方法移除由 addEventListener() 方法添加的事件句柄:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
        <style>
            #Div{
                background-color: coral;
                border: 1px solid;
                padding: 50px;
                color: white;
            }
        </style>
    </head>
    <body>
        <div id="Div">
            <button onclick="removeFunction()">点我</button>
        </div>
        <p id="demo"></p>
    
        <script>
            document.getElementById("Div").addEventListener("mousemove",myFunction);
            function myFunction(){
                document.getElementById("demo").innerHTML=Math.random();
            }
            function removeFunction(){
                document.getElementById("Div").removeEventListener("mousemove",myFunction);
            }
        </script>
    </body>
    </html>

    注意: IE 8 及更早 IE 版本,Opera 7.0及其更早版本不支持 addEventListener() 和 removeEventListener() 方法。但是,对于这类浏览器版本可以使用 detachEvent() 方法来移除事件句柄:

    element.attachEvent(event, function);
    element.detachEvent(event, function);
    跨浏览器解决方法:
    var x = document.getElementById("myBtn");
    if (x.addEventListener) {                    // 所有主流浏览器,除了 IE 8 及更早版本
        x.addEventListener("click", myFunction);
    } else if (x.attachEvent) {                  // IE 8 及更早版本
        x.attachEvent("onclick", myFunction);
    }

  • 相关阅读:
    【原创】elasticsearch入门
    【原创】nginx入门
    【原创】SpringMVC同一RequestMapping返回不同的类型
    [原创]在Centos7.2上源码安装PHP、Nginx、Zentao禅道
    CentOS环境下tomcat启动超级慢的解决方案
    [原创]Nginx反向代理及负载均衡
    常见证书格式和转换
    MySQL基本命令
    研究重力加速度随地球纬度递增的原因
    倒霉的一天
  • 原文地址:https://www.cnblogs.com/SCAU-gogocj/p/13123706.html
Copyright © 2011-2022 走看看