首页 > 代码库 > 事件委托
事件委托
事件委托:利用事件冒泡的原理,把事件添加到父级身上,触发执行效果
好处:
1:提高性能。
2:新添加的元素,还会有之前的事件。
实例:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>无标题文档</title><script>window.onload = function(){ var oUl = document.getElementById(‘ul1‘); var aLi = oUl.getElementsByTagName(‘li‘); var oInput = document.getElementById(‘input1‘); var iNow = 4; /*for(var i=0;i<aLi.length;i++){ aLi[i].onmouseover = function(){ this.style.background = ‘red‘; }; aLi[i].onmouseout = function(){ this.style.background = ‘‘; }; }*/ oUl.onmouseover = function(ev){ var ev = ev || window.event; var target = ev.target || ev.srcElement; if(target.nodeName.toLowerCase() == ‘li‘){ target.style.background = ‘red‘; } }; oUl.onmouseout = function(ev){ var ev = ev || window.event; var target = ev.target || ev.srcElement; if(target.nodeName.toLowerCase() == ‘li‘){ target.style.background = ‘‘; } }; oInput.onclick = function(){ iNow++; var oLi = document.createElement(‘li‘); oLi.innerHTML = 1111 * iNow; oUl.appendChild(oLi); };};</script></head><body><input type="button" value="添加" id="input1" /><ul id="ul1"> <li>111</li> <li>222</li> <li>333</li> <li>444</li></ul></body></html>
事件委托
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。