第一句子网 - 唯美句子、句子迷、好句子大全
第一句子网 > DOM-8 【兼容】冒泡捕获流 事件与事件源对象 事件委托

DOM-8 【兼容】冒泡捕获流 事件与事件源对象 事件委托

时间:2020-11-22 14:41:08

相关推荐

DOM-8 【兼容】冒泡捕获流 事件与事件源对象 事件委托

事件流

1. 含义

描述从页面中接收事件的顺序

2. 分类

IE提出的 事件冒泡流 Event BubblingNetscape提出的 事件捕获流 Event Capturing

3. 阶段

事件捕获阶段

处于目标阶段

事件冒泡阶段

事件捕获先于事件冒泡执行

dom

dom0:定义句柄方式,兼容性最好dom1:没有事件相关定义dom2:addEventListener / removeEventListener W3C规范

事件对象e / window.event

1. W3C标准

e:事件触发后的详细信息,传到事件处理函数的参数里是由MouseEvent构造函数构造的

2. IE

作为window的属性:window.event,不再传到事件处理函数的参数里

事件源(对象)

在事件对象里可获取到srcElement和target:事件源对象火狐只有targetIE只有srcElementchrome都有【兼容】

oDiv.onclick = function (e) {var e = e || window.event,tar = e.target || e.srcElement}

事件委托/事件代理

并不直接给子元素绑定事件,而给父元素绑定(免去了给子元素循环绑定事件的不便)因为子元素被点击后会冒泡给父级判断下事件源tar.tagName.toLowerCase() === 'xxx'则执行相应…

获取下标

循环比较获得下标

oList.onclick = function (e) {var e = e || window.event,tar = e.target || e.srcElement;for (var i = 0; i < len; i++) {item = oLi[i];if (tar === item) {console.log(i);}}}

数组方法查找下标【企业级写法】注意:todoList案例,不能这样判断添加项和现有项是否重复,因为li是引用值

oList.onclick = function (e) {var e = e || window.event,tar = e.target || e.srcElementvar index = Array.prototype.indexOf.call(oLi, tar);console.log(index);}

自定义属性

<body><ul class="test"><li data-index="0">1</li><li data-index="1">2</li><li data-index="2">3</li><li data-index="3">4</li><li data-index="4">5</li><li data-index="5">6</li></ul><script>var oUl = document.getElementsByClassName('test')[0]oUl.onclick = function (e) {var e = e || window.evar tar = e.target || e.srcElementconsole.log(e)console.log(tar)console.log(Number(tar.getAttribute('data-index')))}</script></body>

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。