js DOM0级事件和DOM2级事件

注册事件有两种方式,分别是DOM0级DOM2级

DOM0级就是通过事件绑定的形式dom元素只能有(绑定)一个事件处理函数,他的特点是同一个元素绑定相同事件, 后面函数会覆盖前面的

绑定:

  dom.on+type = 事件处理函数

  dom.onclick = function(){} 函数里面是要执行的功能

btn.onclick = function() {
            alert('hehe');
        }
btn.onclick = function() {
            alert('hihi');
        }
        // 绑定事件兼容处理
        function addEventListener(ele,eventName,callback) {
            if (ele.addEventListener) {
                ele.addEventListener(eventName,callback);
            } else if (ele.attachEvent) {
                ele.attachEvent('on' + eventName, callback);
            } else {
                // ele.onclick = function() {}
                ele['on'+eventName] = callback;
            }
        }
        addEventListener(btn,'click',function() {
            alert('ok');
        });

解除解绑:

  dom.onclick = null

DOM2级是通过事件监听的形式绑定, dom元素可以有(绑定)多个事件处理函数

绑定:

dom.addEventListener(事件字符串,回调函数,布尔值)

IE8以上: dom.addEventListener(type,fn,false)    this指向dom本身    

IE8及以下:dom.attachEvent('on'+type,fn)            this指向window

        // 第一个参数是字符串 表示事件类型 不带on 
        // 第二个参数是事件处理函数
        // 特点 同一个元素可以绑定相同的事件 不会冲突
        btn.addEventListener('click',function() {
            alert('123');
        });
        btn.addEventListener('click',function() {
            alert('456');
        });

        btn.attachEvent('onclick',function() {
            console.log(123);
        });

解除绑定:

  dom.removeEventListener(type,fn,false)   IE8以上

  dom.detachEvent(‘on’+type,fn)       IE8及以下

       function fn() {
            alert('good');
        }

        btn.addEventListener('click',fn);
        
        document.querySelectorAll('button')[1].onclick = function() {
            btn.removeEventListener('click',fn)
        }

        btn.attachEvent('onclick',function() {
            console.log(123);
        });
        document.querySelectorAll('button')[1].onclick = function() {
            btn.detachEvent('onclick',fn)
        }
        // 删除事件兼容处理
        function removeEventListener(ele,eventName,callback) {
            if (ele.removeEventListener) {
                ele.removeEventListener(eventName,callback);
            } else if (ele.detachEvent) {
                ele.detachEvent('on' + eventName, callback);
            } else {
                ele['on'+eventName] = null;
            }
        }

DOM0于DOM2事件绑定的区别
DOM0事件绑定的原理
给当前元素的某一私有属性(onXXX)赋值的过程;(之前属性默认值是null,如果我们赋值了一个函数,就相当于绑定了一个方法)
当我们赋值成功(赋值一个函数),此时浏览器会把DOM元素和赋值的的函数建立关联,以及建立DOM元素的行为监听,当某一行为被用户触发,浏览器会把赋值的函数执行;
DOM0事件绑定的特点:
只有DOM元素天生拥有这个私有属性(onxxx事件私有属性),我们赋值的方法才叫事件绑定,否则属于设置自定义属性
移除事件绑定的时候,我们只需要赋值为null;
在DOM0事件绑定中,只能给当前元素的某一个事件行为绑定一个方法,绑定多个方法,最后一次的绑定的会替换前面绑定的
DOM2事件绑定的原理
DOM2事件绑定使用的 addEventListener/attachEvent方法都是在eventTarget这个内置类的原型上定义的,我们调用的时候,首先要通过原型链找到这个方法,然后执行完成事件绑定的效果
浏览器会给当前元素的某个事件行为开辟一个事件池(事件队列)【浏览器有一个统一的事件池,每个元素绑定的行为都放在这里,通过相关标志区分】,当我们通过 addEventListener/attachEvent进行事件绑定的时候,会把绑定的方法放在事件池中;
当元素的某一行为被触发,浏览器回到对应事件池中,把当前放在事件池的所有方法按序依次执行

猜你喜欢

转载自www.cnblogs.com/lyt0207/p/11919693.html