1、
(缺点 1 for循环影响性能,2每次循环都会在内部创建一个事件,3 如果 li 是动态追加的会导致事件失效。)
var btns=document.getElementsByClassName("btn");//扩展 可以有多种获取DOM方法
for(var i=0;i<btns.length;i++){
btns[i].onclick=function(){
var id=this.getAttribute("data-id");
if(id!="null"){
console.log(id);
}
}
}
2、
(解决了方案一种的2,3缺点,但是还有for循环!IOS下事件委托失效解决方案)
var btns=document.getElementsByClassName("btn");
function handleClick(){
var id=this.getAttribute("data-id");
if(id!="null"){
console.log(id);
}
}
for(var i=0;i<btns.length;i++){
btns[i].addEventListener("click",handleClick,false);
}
3、
(完美解决方案1种的所有缺点)
涉及知识点:addEventListener,event
var parent=document.getElementById("parent");
function handleClick(){
var e=window.event||arguments[0];
var target=e.srcElement||e.target;
if(target.nodeName.toLowerCase() == 'li'){
var id=target.getAttribute("data-id");
if(id!="null"){
console.log(id);
}
}
}
parent.addEventListener("click",handleClick,false);
温馨提示:答案为网友推荐,仅供参考