html5中文学习网

您的位置: 首页 > 网站及特效实例 > javascript特效 » 正文

理解JS绑定事件_javascript技巧_

[ ] 已经帮助:人解决问题

本文为大家详细分析了JS绑定事件,供大家参考,具体内容如下9dmHTML5中文学习网 - HTML5先行者学习网

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

 function addEvent(obj, eventType, callback, bubble){ if(obj.addEventListener){  obj.addEventListener(eventType, callback, bubble); }else{  obj.attachEvent(eventType, callback, bubble); } }

调用时,注意callback函数不需要加括号,与setTimeout类似。9dmHTML5中文学习网 - HTML5先行者学习网

这部分都比较容易理解,对于最后一个参数,相信很多人并不是非常理解,总之我还是需要写程序测试一下才真正弄通。9dmHTML5中文学习网 - HTML5先行者学习网

HTML部分内容:9dmHTML5中文学习网 - HTML5先行者学习网

<!doctype html><html lang="en">  <head>  <!--网站编码格式,UTF-8 国际编码,GBK或 gb2312 中文编码-->    <meta charset="UTF-8">    <meta name="Keywords" content="关键词一,关键词二">    <meta name="Description" content="网站描述内容">    <meta name="Author" content="">    <title>Document</title>  <!--css js 文件的引入-->  </head>  <body>    <div id="out">     <p>我是路人甲</p>    <div id="middle">       <div id="inner">最里面的</div>     </div>     <p>我是路人乙</p>    </div>  </body></html>

js内容:(第一种情况)9dmHTML5中文学习网 - HTML5先行者学习网

<script>  var out = document.getElementById('out');   var middle = document.getElementById('middle');   var inner = document.getElementById('inner');   //点击inner时,触发顺序为:inner-------middle------out  out.addEventListener('click',function(){alert("我是最外面的");},false);     middle.addEventListener('click',function(){alert("我是中间的");},false);      inner.addEventListener('click',function(){alert("我是最里面的");},false); </script>

js内容:(第二种情况)9dmHTML5中文学习网 - HTML5先行者学习网

<script>  var out = document.getElementById('out');   var middle = document.getElementById('middle');   var inner = document.getElementById('inner');   //点击inner时,触发顺序为:out------inner-------middle  out.addEventListener('click',function(){alert("我是最外面的");},true);     middle.addEventListener('click',function(){alert("我是中间的");},true);    inner.addEventListener('click',function(){alert("我是最里面的");},true); </script>

js内容:(第三种情况)9dmHTML5中文学习网 - HTML5先行者学习网

9dmHTML5中文学习网 - HTML5先行者学习网

<script>  var out = document.getElementById('out');   var middle = document.getElementById('middle');   var inner = document.getElementById('inner');   //点击inner时,触发顺序为:out------inner-------middle  out.addEventListener('click',function(){alert("我是最外面的");},true);     middle.addEventListener('click',function(){alert("我是中间的");},false);      inner.addEventListener('click',function(){alert("我是最里面的");},false);</script>

js内容:(第四种情况)9dmHTML5中文学习网 - HTML5先行者学习网

9dmHTML5中文学习网 - HTML5先行者学习网

<script>  var out = document.getElementById('out');   var middle = document.getElementById('middle');   var inner = document.getElementById('inner');   //点击inner时,触发顺序为:out-------middle------inner  out.addEventListener('click',function(){alert("我是最外面的");},true);     middle.addEventListener('click',function(){alert("我是中间的");},true);    inner.addEventListener('click',function(){alert("我是最里面的");},false);</script>

js内容:(第五种情况)9dmHTML5中文学习网 - HTML5先行者学习网

<script>  var out = document.getElementById('out');   var middle = document.getElementById('middle');   var inner = document.getElementById('inner');   //点击inner时,触发顺序为:middle-------inner------out  out.addEventListener('click',function(){alert("我是最外面的");},false);     middle.addEventListener('click',function(){alert("我是中间的");},true);    inner.addEventListener('click',function(){alert("我是最里面的");},false);</script>

js内容:(第六种情况)9dmHTML5中文学习网 - HTML5先行者学习网

<script>  var out = document.getElementById('out');   var middle = document.getElementById('middle');   var inner = document.getElementById('inner');   //点击inner时,触发顺序为:out-------inner------middle  out.addEventListener('click',function(){alert("我是最外面的");},true);     middle.addEventListener('click',function(){alert("我是中间的");},false);      inner.addEventListener('click',function(){alert("我是最里面的");},true);</script>

看完以上六种情况对应的结果,相信您已经能够深刻理解,最后一个参数为true或false的区别了。9dmHTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助