常见场景:页面有多个相同的按钮需要绑定同样的事件逻辑。

如下HTML,实现:点击每个按钮,当它的 data-id不为null的时候输出它的data-id(实际业务中会有更复杂的逻辑)

    <ul id="parent">
<li class="btn" data-id="1">按鈕1</li>
<li class="btn" data-id="2">按鈕2</li>
<li class="btn" data-id="null">按鈕3</li>
<li class="btn" data-id="3">按鈕4</li>
<li class="btn" data-id="null">按鈕5</li>
</ul>

实现方案一:(缺点 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,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);
}

实现方案三:(完美解决方案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);

方案三的升级版:注册绑定事件方便复用

// 1、通用綁定事件
function bind(elem,eventType,callback){
if(elem.addEventListener){
elem.addEventListener(eventType,callback,false);
}else{
elem.attachEvent("on"+eventType,function(){
callback.call(elem);
});
}
} 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);
}
}
}
bind(parent,"click",handleClick);

最新文章

  1. JSP的基本语法
  2. git --- push到远端
  3. Linux下安装部署Java
  4. inline-block使标签间出现空白
  5. 挖Linux中的古老缩略语
  6. EventLog实现事件日志操作
  7. ViewPager的setOnPageChangeListener方法详解
  8. 桦仔 笔记7-徐 SQLSERVER日志记录机制
  9. android资源文件的选取
  10. 基于PT的ipv6 ripng配置
  11. Python网络爬虫与如何爬取段子的项目实例
  12. java项目---遍历系统文件(1星)
  13. 执行Runtime.exec()需要注意的陷阱
  14. 字符编码ASCII,Unicode 和 UTF-8
  15. Codeforces 1077C Good Array 坑 C
  16. Fantacy团队周一站立会议
  17. greenplum不能下载问题解决方法(转)
  18. 外网IP监测上报程序(使用Poco库的SMTPClientSession发送邮件)
  19. MYSQL 线程池
  20. python浮窗

热门文章

  1. 一个基于JRTPLIB的轻量级RTSP客户端(myRTSPClient)——实现篇:(五)用户接口层之提取媒体流数据
  2. 使用TenforFlow 搭建BP神经网络拟合二次函数
  3. 如何将Windows7系统中“运行”历史记录全部清除
  4. 2017-04-21周Java学习笔记
  5. SpringMVC详解(六)------与json交互
  6. Andrew Ng机器学习课程笔记--week2(多元线性回归&amp;正规公式)
  7. hdu3720 Arranging Your Team
  8. java中接口实现多态举例
  9. 代码精简之Lombok
  10. LAMP一键安装