这篇文章主要帮助大家深入理解 JS 绑定事件,介绍了六种 JS 绑定事件的情况,感兴趣的小伙伴们可以参考一下
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
绑定事件有兼容性问题,在 IE 早期版本中使用的是 obj.attachEvent(),而其他浏览器使用的则是 addEventListener()。
这两个方法都有三个参数,分别为:事件类型,事件函数,最后一个是布尔值,true 或者是 false。
true 表示在事件捕获阶段执行,false 表示在事件冒泡阶段执行。
由于 IE 只支持事件冒泡,所以同大多数情况下,都是将事件处理程序添加到事件流的冒泡阶段,即默认为 "false"
这样可以最大限度地兼容各种浏览器。 最好只在需要在是事件到达目标之前截获它的时候将事件处理程序添加到捕获阶段。 如果不是特别需要,不建议在事件捕获阶段注册事件处理程序。
兼容各浏览器的事件绑定:
- function addEvent(obj, eventType, callback, bubble){
- if(obj.addEventListener){
- obj.addEventListener(eventType, callback, bubble);
- }else{
- obj.attachEvent(eventType, callback, bubble);
- }
- }
调用时,注意 callback 函数不需要加括号,与 setTimeout 类似。
这部分都比较容易理解,对于最后一个参数,相信很多人并不是非常理解,总之我还是需要写程序测试一下才真正弄通。
html 部分内容:
- <!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 内容:(第一种情况)
- <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 内容:(第二种情况)
- <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 内容:(第三种情况)
- <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 内容:(第四种情况)
- <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 内容:(第五种情况)
- <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 内容:(第六种情况)
- <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 的区别了。
来源: http://www.phperz.com/article/17/0222/267501.html