JavaScript之事件处理详解(2)

可以通过设置某一事件目标的事件处理程序属性来为其注册相应的事件处理程序。事件处理程序属性名字由“on”后面跟着事件名组成,例如:onclick、onmouseover。实例:

<!DOCTYPE HTML>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title>test</title>
    <style type="text/css">
        #div1{width: 300px; height: 300px; background: red; overflow:hidden;}
        #div2{margin:50px auto; width: 200px; height: 200px; background: green; overflow:hidden;}
        #div3{margin:50px auto; width: 100px; height: 100px; background: blue;}
    </style>
</head>
<body>
    <div>div1
        <div>div2
            <div>div3
            </div>
        </div>
    </div>
 <script type="text/javascript">
    var div1 = document.getElementById('div1');
    var div2 = document.getElementById('div2');
    var div3 = document.getElementById('div3');
    div1.onclick = function(){
       console.log('div1');
    };
    div2.onclick = function(){
       console.log('div2');
    };
    div3.onclick = function(){
       console.log('div3');
    };
    div1.onclick = function(){
       console.log('div11111');
    };
  div1.onClick = function(){
    console.log('DIV11111');
  };
 </script>
</body>
</html>

结果(鼠标点击div3区域后):

JavaScript之事件处理详解

从结果中可以看出:

①因为JavaScript是严格区分大小写的,所以,这种形式下属性名只能按规定小写;

②若给同一元素对象写多个onclick事件处理属性,后面写的会覆盖前面的(ps:这就是在修改一个对象属性的值,属性的值是唯一确定的);

③这种形式也是在事件冒泡过程中注册事件处理程序的;

3.addEventListener()

前两种方式出现在Web初期,众多浏览器都有实现。而addEventListener()方法是标准事件模型中定义的。任何能成为事件目标的对象——这些对象包括Window对象、Document对象和所有文档元素等——都定义了一个名叫addEventListener()的方法,使用这个方法可以为事件目标注册事件处理程序。addEventListener()接受三个参数:第一个参数是要注册处理程序的事件类型,其值是字符串,但并不包括前缀“on”;第二个参数是指当指定类型的事件发生时应该调用的函数;第三个参数是布尔值,其可以忽略(某些旧的浏览器上不能忽略这个参数),默认值为false。这种情况是在事件冒泡过程中注册事件处理程序。当其为true时,就是在事件捕获过程中注册事件处理程序。实例:

<!DOCTYPE HTML>
<html>
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
   <title>test</title>
   <style type="text/css">
      #div1{width: 300px; height: 300px; background: red; overflow:hidden;}
      #div2{margin:50px auto; width: 200px; height: 200px; background: green; overflow:hidden;}
      #div3{margin:50px auto; width: 100px; height: 100px; background: blue;}
   </style>
</head>
<body>
   <div>div1
      <div>div2
         <div>div3
         </div>
      </div>
   </div>
 <script type="text/javascript">
    var div1 = document.getElementById('div1');
    var div2 = document.getElementById('div2');
    var div3 = document.getElementById('div3');
    div1.addEventListener('click', function(){ console.log('div1-bubble'); }, false);
    div2.addEventListener('click', function(){ console.log('div2-bubble'); }, false);
    div3.addEventListener('click', function(){ console.log('div3-bubble'); }, false);
    div3.addEventListener('click', function(){ console.log('div3-bubble222'); }, false);
    div1.addEventListener('click', function(){ console.log('div1-capturing'); }, true);
    div2.addEventListener('click', function(){ console.log('div2-capturing'); }, true);
    div3.addEventListener('click', function(){ console.log('div3-capturing'); }, true);
 </script>
</body>
</html>

结果(鼠标点击div3区域后):

JavaScript之事件处理详解

从结果中可以看出:

①addEventListener()第三个参数的作用正如上面所说;

②通过addEventListener()方法给同一对象注册多个同类型的事件,并不会发生忽略或覆盖,而是会按顺序依次执行;

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/18c5e201c636b0b302cb42feac24acd9.html