理解JS绑定事件

本文为大家详细分析了JS绑定事件,供大家参考,具体内容如下

绑定事件有兼容性问题,在IE早期版本中使用的是obj.attachEvent(),而其他浏览器使用的则是addEventListener()。 这两个方法都有三个参数,分别为:事件类型,事件函数,最后一个布尔值,true或者是false。 true表示在事件捕获阶段执行,false表示在事件冒泡阶段执行。 由于IE只支持事件冒泡,所以同大多数情况下,都是将事件处理程序添加到事件流的冒泡阶段,即认为”false” 这样可以最大限度地兼容各种浏览器。 最好只在需要在是事件到达目标之前截获它的时候将事件处理程序添加到捕获阶段。 如果不是特别需要,不建议在事件捕获阶段注册事件处理程序。 兼容各浏览器的事件绑定:

rush:js;"> function addEvent(obj,eventType,callback,bubble){ if(obj.addEventListener){ obj.addEventListener(eventType,bubble); }else{ obj.attachEvent(eventType,bubble); } }

调用时,注意callback函数不需要加括号,与setTimeout类似。

这部分都比较容易理解,对于最后一个参数,相信很多人并不是非常理解,总之我还是需要写程序测试一下才真正弄通。

HTML部分内容

rush:xhtml;"> <Meta charset="UTF-8"> <Meta name="Keywords" content="关键词一,关键词二"> <Meta name="Description" content="网站描述内容"> <Meta name="Author" content=""> Document
我是路人甲

我是路人乙

js内容:(第一种情况)

rush:js;">

js内容:(第二种情况)

rush:js;">

js内容:(第三种情况)

<div class="jb51code">
<pre class="brush:js;">

js内容:(第四种情况)

<div class="jb51code">
<pre class="brush:js;">

js内容:(第五种情况)

rush:js;">

js内容:(第六种情况)

rush:js;">

看完以上六种情况对应的结果,相信您已经能够深刻理解,最后一个参数为true或false的区别了。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...