• JavaScript


    JavaScript - DOM事件的优化

    因为如果在标签里面写时间的话 耦合度非常低...

    所以呢 我们有 

    addEventListener()  和 removeEventListener()  方法可以捆绑和解绑事件:

    1.
    addEventListener() 

    定义和用法

    addEventListener() 方法用于向指定元素添加事件句柄。
    注意: Internet Explorer 8 及更早IE版本不支持 addEventListener() 方法,,Opera 7.0 及 Opera 更早版本也不支持。 但是,对于这些不支持该函数的浏览器,你可以使用 attachEvent() 方法来添加事件句柄 

    语法 注意 !参1 不带 on 比如 onclck事件 就写  clck啊!

    element.addEventListener(eventfunctionuseCapture)
     
    参数描述
    event 必须。字符串,指定事件名。

    注意: 不要使用 "on" 前缀。 例如,使用 "click" ,而不是使用 "onclick"。

    提示: 所有 HTML DOM 事件,可以查看我们完整的 HTML DOM Event 对象参考手册。
    function 必须。指定要事件触发时执行的函数。

    当事件对象会作为第一个参数传入函数。 事件对象的类型取决于特定的事件。例如, "click" 事件属于 MouseEvent(鼠标事件) 对象。
    useCapture 可选。布尔值,指定事件是否在捕获或冒泡阶段执行。

    可能值:
    • true - 事件句柄在捕获阶段执行
    • false- false- 默认。事件句柄在冒泡阶段执行

    2.addEventListener() 

    定义和用法

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

    注意: 如果要移除事件句柄,addEventListener() 的执行函数必须使用外部函数,

    匿名函数,是无法移除的。

    语法

    element.removeEventListener(eventfunctionuseCapture)

    参数值

    ParameterDescription
    event 必须。要移除的事件名称。.

    注意:不要使用 "on" 前缀。 例如,使用 "click" ,而不是使用 "onclick"。

    提示: 所有 HTML DOM 事件,可以查看我们完整的 HTML DOM Event 对象参考手册。
    function 必须。指定要移除的函数。
    useCapture 可选。布尔值,指定移除事件句柄的阶段。

    可能值:
    • true - 在捕获阶段移除事件句柄
    • false- 默认。在冒泡阶段移除事件句柄
    注意: 如果添加两次事件句柄,一次在捕获阶段,一次在冒泡阶段,你必须单独移除该事件

     

     注意他们的调用者是他们的元素节点啊!

    还是上个例子吧:

    <!doctype html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport"
              content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>javascript study</title>
    </head>
    <body>
    <p>点我</p>
    
    <script type="text/javascript">
        let ele = document.getElementsByTagName('p')[0];
        ele.addEventListener("click" ,fun,false);
    
        function fun(){
            document.write("ok!");
        }
    </script>
    </body>
    </html>

     






    本文来自博客园,作者:咸瑜,转载请注明原文链接:https://www.cnblogs.com/bi-hu/p/14775745.html

  • 相关阅读:
    ctags的基本操作总结
    iOS开发使用Unwind Segue进行返回
    Swoole源代码学习记录(十二)——ReactorThread模块
    HDU 2189 ( 悼念512汶川大地震遇难同胞——来生一起走 )
    WEB开发面试题
    UVA 11762
    shell EOF注意点
    Oracle EBS 从Web界面进入责任时,提示不存在可用的有效责任
    LeetCode--Reverse Integer
    atitit.web 推送实现方案集合
  • 原文地址:https://www.cnblogs.com/bi-hu/p/14775745.html
Copyright © 2020-2023  润新知