美文网首页
绑定事件的方法

绑定事件的方法

作者: 婳噫 | 来源:发表于2019-06-18 20:11 被阅读0次
  1. HTML事件处理程序
    缺点:
    时差问题: 用户可能会在HTML元素一出现在页面上就触发响应;的事件,但当时的事件处理程序有可能尚不具备执行条件,就会引发错误
    HTML与JavaScript代码紧密耦合

  2. DOM0级处理事件
    优势:具有跨浏览器的优势
    缺陷:只能绑定一次事件处理程序

    绑定事件: element.on + '事件类型' = 事件处理程序
    解绑事件: element.on + '事件类型' = null;

  3. DOM2级事件处理程序
    绑定事件
    element.addEventListener(要处理的事件名, 作为处理程序的函数, 是否在捕获阶段调用事件处理程序)
    要处理的事件名
    'click'
    处理程序的函数
    function () {}
    函数名
    是否在捕获阶段调用事件处理程序
    true: 在捕获阶段调用事件处理程序
    false: 在冒泡阶段调用事件处理程序(默认)
    解绑事件
    ele.removeEventListener('click', 事件名);
    如果事件处理程序是匿名函数则无法解绑

    特点: 可以多次绑定不同的事件处理程序,并且会按照它们的绑定顺序执行

  4. IE事件处理程序

    绑定事件
    ele.attachEvent(事件名, 事件处理程序函数)
    事件名
    'onclick'
    事件处理程序函数
    function () {}
    函数名

    解绑事件
    ele.detachEvent(事件名, 事件处理程序函数)
    条件必须提供相同的参数
    事件处理程序函数也必须是有名函数

    IE只支持事件冒泡
    attachEvent()也可以绑定多个事件处理程序函数,但是它的执行顺序与addEventListener的执行顺序相反(IE9 IE10 采用的是addEventListener)

    attachEvent()与使用DOM0级方法的主要区别,在于事件处理程序的作用域
    在使用DOM0级方法的情况下,事件处理程序会在其所属元素的作用域内运行
    在使用attachEvent()方法情况下,事件处理程序会在全局作用域中运行,因此this等于window

相关文章

  • JS-事件绑定

    一、addEventListener : 事件绑定另外一种绑定事件的方法。优点:可以绑定多个事件,之后绑定的事件...

  • Jquery事件处理

    绑定事件 bind(map)方法 bind(type, [data], fn)方法 在为对象绑定事件的同时,为事件...

  • JavaScript事件

    事件分类 事件的绑定方法 通过标签绑定事件 通过js获取DOM元素绑定事件 通过addEventListener属...

  • Android第二课 事件绑定

    事件绑定采用setOnClickListener方法绑定事件 setOnClickListener setOnCl...

  • jquery入门(3)

    4.jQuery中的事件绑定 #4.1.事件绑定 on方法绑定 直接绑定 总结:事件里面的this是原生的this...

  • vue学习笔记(二)属性绑定,鼠标事件,事件修饰符,按键修饰符

    vue中属性绑定 vue中事件绑定 在标签方法名前加 @ 进行事件绑定![a标签click成功绑定add方法] 事...

  • web前端 -- Day20 js基础

    为元素绑定多个事件 绑定事件的区别事件绑定的方法: 相同点:都可以为事件绑定元素不同点: 方法名不一样; 参数个数...

  • 2018-02-13

    1.jquery on方法用于绑定事件 ,为标签绑定事件 为段落p绑定click事件,$("p").on(clic...

  • js跟jq的事件绑定以及解绑

    事件绑定 基本的事件绑定 其他事件绑定 On 替代bind方法/解绑用unbind on代替live动态创建元素绑...

  • dom 事件绑定

    dom绑定事件有两种方法: onclickonclick绑定事件,分为两种方法,一种是行内绑定,一种是动态绑定行内...

网友评论

      本文标题:绑定事件的方法

      本文链接:https://www.haomeiwen.com/subject/rrvqqctx.html