• Web APIs:事件高级--注册事件(绑定事件)


    注册事件俩种方式

    给元素添加事件,称为注册事件或者绑定事件

    注册事件有两种方式:传统方式和方法监听注册方式

    传统注册方式

    利用 on 开头的事件 onclick

    btn.onclick = function() {}

    特点: 注册事件的唯一性

    同一个元素同一个事件只能设置一个处理函数,最 后注册的处理函数将会覆盖前面注册的处理函数

     方法监听注册方式 

    w3c 标准 推荐方式

    addEventListener() 它是一个方法

    IE9 之前的 IE 不支持此方法,可使用 attachEvent() 代替

    特点:同一个元素同一个事件可以注册多个监听器(函数function({}))

    按注册顺序依次执行

    addEventListener 事件监听方式

    eventTarget.addEventListener(type, listener[, useCapture])

    eventTarget.addEventListener()方法将指定的监听器注册到 eventTarget(目标对象)上,当该对 象触发指定的事件时,就会执行事件处理函数。

    该方法接收三个参数:

    type:事件类型字符串,比如 click 、mouseover ,注意这里不要带 on

    listener:事件处理函数,事件发生时,会调用该监听函数

    useCapture:可选参数,是一个布尔值,默认是 false。

     代码总结

    1. <!DOCTYPE html>
    2. <html>
    3. <head>
    4. <meta charset="utf-8">
    5. <title></title>
    6. </head>
    7. <body>
    8. <button>传统注册事件</button>
    9. <button>方法监听注册事件</button>
    10. <script>
    11. var btns=document.querySelectorAll('button');
    12. // 1,传统注册事件
    13. btns[0].onclick=function(){
    14. alert('1')
    15. }
    16. btns[1].onclick=function(){
    17. alert('2')//最终它只会显示2 因为传统的唯一性
    18. }
    19. //2.方法监听注册事件 addEventListener里面的
    20. // 1.类型为字符串 必定加引号 而且不能用on
    21. // 2.通一个元素 同一个事件可以添加多个侦听器(事件处理程序)
    22. btns[1].addEventListener('click',function(){
    23. alert(22)
    24. })
    25. btns[1].addEventListener('click',function(){
    26. alert(33)
    27. })
    28. </script>
    29. </body>
    30. </html>

     attachEvent注册事件(ie9以前用这种方法)

    eventTarget.attachEvent(eventNameWithOn, callback)

    eventTarget.attachEvent()方法将指定的监听器注册到 eventTarget(目标对象)上,当该对象触 发指定的事件时,指定的回调函数就会被执行。

    该方法接收两个参数:

    eventNameWithOn:事件类型字符串,比如 onclick 、onmouseover ,这里要带 on

    callback: 事件处理函数,当目标触发事件时回调函数被调用

    注意:IE8 及早期版本支持(ie都淘汰了,了解就好了) 

    // 3.attachEvent ie 独有的 别的游览器没有效果的
                btns[2].attachEvent('onclick',function(){
                    alert(11);
                }) 

  • 相关阅读:
    LeetCode 101. 对称二叉树
    初阶数据结构 遍历二叉树问题 (一)
    Redis主从复制
    洛谷 P1021 邮票面值设计
    07-prometheus的自定义监控-pushgateway工具组件
    PMP每日一练 | 考试不迷路-10.29(包含敏捷+多选)
    计算机网络---第五章传输层
    【设计模式】策略模式
    化妆品展示网页设计作业 静态HTML化妆品网站 DW美妆网站模板下载 大学生简单网页作品代码 个人网页制作 学生个人网页设计作业
    在Jupyter Notebook中更新模块不丢失变量的方法:使用importlib.reload
  • 原文地址:https://blog.csdn.net/weixin_64612659/article/details/127038387