DOM0,DOM2,DOM3的区别

2019-06-18  本文已影响0人  泉泉泉泉泉泉

DOM级别

DOM级别一共可以分为四个级别:DOM0级、DOM1级、DOM2级和DOM3级。而DOM事件分为3个级别:DOM0级事件处理,DOM2级事件处理和DOM3级事件处理。

DOM0

 <button type="button" onclick="showFn()"></button>
  function showFn() {
      alert('Hello World');
  }
 <button id="btn" type="button"></button>
    var btn = document.getElementById('btn');
    btn.onclick = function() {
        console.log('Hello World');
    }

以上这两种写法都属于DOM0级别的事件处理,从上面的代码中可以看出其优缺点如下:
优点

DOM2

<button id="btn" type="button"></button>
    var btn = document.getElementById('btn');    
    function showFn() {
        alert('Hello World');
    }    
    btn.addEventListener('click', showFn, false);
    // btn.removeEventListener('click', showFn, false); 解绑事件 

DOM2级事件定义了addEventListener 和 removeEventListener两个方法,分别用来绑定和解绑事件,方法中包含三个参数,分别是绑定的事件处理的属性名称(没有on) 、处理函数和是否在捕获时候执行事件处理函数如果我们还需要添加一个鼠标的移入的方法,只需要:

需要注意的是IE8以下版本不支持 addEventlistener 和 removeEventListerner
需要使用attachEvent和detachEvent实现:

 btn.attachEvent('onclick', showFn); // 绑定事件 
 btn.detachEvent('onclick', showFn); // 解绑事件

这里我们不需要传入第三个参数,因为IE8以下版本只支持冒泡型事件。

DOM3

DOM3级事件是在DOM2级事件的基础上添加很多事件类型。

PS : 为什么没有DOM1级事件处理呢?
因为1级DOM标准并没有定义事件相关的内容,所以没有所谓的1级DOM事件模型。

参考博客:https://www.jianshu.com/p/622d994906f7
https://www.jianshu.com/p/01c2688db289

上一篇 下一篇

猜你喜欢

热点阅读