我们使用的DOM2事件绑定,其实是让box通过原型链一直找到EventTarget这个内置类原型上的addEventListener方法实现的。
DOM0级事件绑定:只能给一个元素的某一个行为绑定一次方法,第二次绑定的会把前面的覆盖掉。
DOM2:可以给某一个元素的同一个行为绑定多个不同的方法
box.addEventListener('click',function(e){ console.log(1) },false) box.addEventListener('click',function(e){ console.log(2) },false) // 输出1 2
DOM2:DOM0中的行为类型,我们用DOM2一样可以绑定,而且DOM2中还提供了一些DOM0没有的行为类型->DOMContentLoaded:当页面中的DOM结构(HTML结构加载完成)触发的行为
box.addEventListener('DOMContentLoaded',function(e){ },false)
window.onload = function(){} //当页面中的所有资源都加载完成(图片、HTML结构、音视频...)才会执行后面的函数;并且在一个页面中只能用一次,后面在写会把前面的覆盖掉;->因为他是采用DOM0事件绑定,所以只能绑定一次 $(document).ready(function(){})//->$(function(){}) /* 只要页面中的HTML结构加载完成就会执行对应的函数;并且在同一个页面中可以出现多次。因此这个是采用DOM2事件的绑定,绑定的行为是DOMContentLoaded */
DOM2级添加和移除事件细节
function fn1(e){ console.log(this); } //添加事件 box.addEventListener('click',fn1,false); //移除事件 box.removeEventListener('click',fn1,false);
注意:移除的时候需要保证三个参数:行为、方法、哪个阶段发生的 三个参数必须一致 ->DOM2在绑定的时候,我们一般都给他绑定的是实名函数
只能给某个元素的同一个行为绑定多个“不同”的方法(如果方法相同了,只能留一个)
当行为触发,会按照绑定的先后顺序依次把绑定的方法执行;执行的this是当前被绑定事件的元素本身
function fn1(){ console.log(1); } //添加事件 box.addEventListener('click',fn1,false); box.addEventListener('click',fn1,false);//只输出一个1
上面涉及一个概念:事件池(用来存储当前元素行为绑定的方法的,浏览器自带的机制) 如下图所示
但是在IE6-8浏览器中,不支持addEventListener,如果想实现DOM2事件绑定只能用attachEvent/detachEvent
它只有两个参数,不能像addEventListener那样控制在哪个阶段发生,默认只能在冒泡阶段发生,同时行为需要添加on(和DOM0特别的类似)
box.attachEvent('onclick',fn1)
注意:和标准浏览器的事件池机制对比:
1、顺序问题:执行的时候顺序是混乱的,标准浏览器是按照绑定顺序依次执行的
2、重复问题:ie6-8可以给同一个元素的同一个行为绑定多个相同的方法
3、this问题:ie6-8中当方法执行的时候,方法中的this不是当前的元素box而是window
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 证声音乐图书馆《真夏派对 x 浩室》[320K/MP3][67.19MB]
- 张镐哲.1994-无助【波丽佳音】【WAV+CUE】
- Relic.2024-浮在虛无的诗意【SEEAHOLE】【FLAC分轨】
- 群星.2001-台语(原主唱)排行总冠军黄金典藏版6CD【柯达唱片】【WAV+CUE】
- 证声音乐图书馆《真夏派对 x 浩室》[FLAC/分轨][379.1MB]
- 徐良《东西世界》[WAV+CUE][1.1G]
- 证声音乐图书馆《真夏派对 x 迪斯可》[320K/MP3][67.9MB]
- TheDutchSwingCollegeBand-JubileeConcert(LiveRemastered2024)(1980)[24Bit-96kHz]FLAC
- 永恒英文金曲精选6《TheBestOfEverlastingFavouritesVol.6》[WAV+CUE]
- ABC唱片-鲍比达·新民乐《满江红》[APE+CUE]
- 许嵩.2014-不如吃茶去【海蝶】【WAV+CUE】
- 周笔畅.2024-HAVE.A.GOOD.NIGHT【SN.Music】【FLAC分轨】
- 周笔畅.2024-HAVE.A.NICE.DAY【SN.Music】【FLAC分轨】
- 证声音乐图书馆《真夏派对 x 迪斯可》[FLAC/分轨][380.78MB]
- 证声音乐图书馆《星空下 爵士钢琴》[320K/MP3][65.88MB]