美文网首页
事件绑定,以及事件冒泡,事件捕获

事件绑定,以及事件冒泡,事件捕获

作者: 米亚MIA | 来源:发表于2017-03-20 17:42 被阅读102次

当我们想去操作html文档中的某个元素,使其发生某种变化时,这都少不了事件绑定。

今天主要想写一下最基本的一些用法和注意点。

第一,事件绑定

(1)在元素的标签中,使用 on+事件名的方法。此种方法简单,也不存在什么兼容问题,但是没有实现代码分离,且只能绑定一个函数。

1.1在html中

(2)第二种方法与第一种方法类似,只是事件绑定放到了js中。这实现了代码分离,也很简单。但是功能较弱,也只能实现一个函数的绑定。

1.2 在js中使用.on事件名的方法

(3)添加事件监听

这种方法,addEventListener可以同时绑定多个函数,在W3C标准下,为先绑定先执行。此外,此方法还有其它优点,可以在第三个参数下,指定是在事件冒泡时执行,还是事件捕捉时执行。此外,第二个参数,如果我们直接写一个函数,在函数中传入事件(e),我们可以直接捕捉到触发事件。最后还有一个注意点,就是函数体中的this,是添加事件监听前的元素。

这种方法优点这么多,所以我们自然优先选择这种方法,但是要注意,IE 不支持,要使用attachEvent.

1.3 addEventListener

第二 jQuery中的事件绑定

由于jQuery的使用频度较高,这里简略提一下jQuery中我们常用的事件绑定方法。

(1)$(选择器).bind(事件类型,[data],function(){}); 

(2) 可以将上述简写成,$(选择器).事件(function(){}); 

eg.  a.click(function(){ alert("a is clicked");});

(3)使用on. 

on(type,[selector],[data],fn)

这里有较为详细一些的,关于jQuery中的事件绑定 http://www.51edu.com/it/bckf/35687.html

第三,事件冒泡,事件捕获以及应用。

1)冒泡事件

冒泡事件如其名字,是从一个具体的元素的事件的触发,逐渐扩散到最不具体的事件目标(document)。我们最常用的一个应用,就是如果多个元素需要触发相同事件,或者动态添加某些元素导致无法绑定事件时,可以将事件触发绑定到父元素上,这样在子元素上的事件也会使父元素触发相应函数,这就叫做事件委托。

2)事件捕获

定义与事件冒泡相反,就是从最不具体的事件逐级捕获到最具体的事件。

3) 事件流

DOM事件流:同时支持两种事件模型:捕获型事件和冒泡型事件,但是,捕获型事件先发生。两种事件流会触及DOM中的所有对象,从document对象开始,也在document对象结束。在addEventListener中,将第三个参数设置为false,则是在冒泡事件中执行。这与IE默认的事件模型一致。

参考文章:

事件绑定:

http://www.cnblogs.com/ninofocus/archive/2012/11/07/2758772.html

http://www.itxueyuan.org/view/6338.html

冒泡及事件流:http://www.jb51.net/article/42492.htm

相关文章

  • 事件绑定,以及事件冒泡,事件捕获

    当我们想去操作html文档中的某个元素,使其发生某种变化时,这都少不了事件绑定。 今天主要想写一下最基本的一些用法...

  • 事件

    事件顺序 先执行捕获事件,然后目标阶段,再执行冒泡事件 给一个dom即绑定了捕获,又绑定了冒泡,那么先绑定什么事件...

  • 原始类型与事情委托

    1.绑定事件: 二、事件冒泡与事件捕获 事件委托 案例见事件委托 计时器

  • 事件生僻知识学习笔记

    DOM2 级事件包括: 事件捕获,处于目标,事件冒泡 绑定事件方法: HTML上直接绑定 DOM0级事件处理程序 ...

  • Javascript事件系统

    本文内容 事件基础 事件监听方式 事件默认行为 事件冒泡与事件捕获 事件绑定与事件委托 事件基础 注意:本文不会深...

  • 微信小程序中bind和catch的区别

    bindtap 冒泡事件,事件绑定不会阻止冒泡事件向上冒泡catchtap 非冒泡事件, 事件绑定阻止冒泡事件...

  • 事件代理及常用的 HTML 事件

    之前总结了事件捕获和冒泡以及阻止事件传播,今天写一下事件代理方面的总结DOM 事件之捕获、冒泡:阻止事件传播: 事...

  • js运用

    1.属性操作 2.BOM操作 3.计时事件 4.事件绑定 事件冒泡和事件捕获

  • 事件绑定 和 方法传值

    冒泡和非冒泡事件绑定 bindtap: 冒泡事件绑定 catchtap: 非冒泡事件绑定当其他的事件冒泡到当前元素...

  • Javascript事件系统

    本文内容:事件基础事件监听方式事件默认行为事件冒泡与事件捕获事件绑定与事件委托事件基础注意:本文不会深入探究Jav...

网友评论

      本文标题:事件绑定,以及事件冒泡,事件捕获

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