JS中如何巧妙的用事件委托
2024-08-24 21:26:17
常见场景:页面有多个相同的按钮需要绑定同样的事件逻辑。
如下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);
最新文章
- JSP的基本语法
- git --- push到远端
- Linux下安装部署Java
- inline-block使标签间出现空白
- 挖Linux中的古老缩略语
- EventLog实现事件日志操作
- ViewPager的setOnPageChangeListener方法详解
- 桦仔 笔记7-徐 SQLSERVER日志记录机制
- android资源文件的选取
- 基于PT的ipv6 ripng配置
- Python网络爬虫与如何爬取段子的项目实例
- java项目---遍历系统文件(1星)
- 执行Runtime.exec()需要注意的陷阱
- 字符编码ASCII,Unicode 和 UTF-8
- Codeforces 1077C Good Array 坑 C
- Fantacy团队周一站立会议
- greenplum不能下载问题解决方法(转)
- 外网IP监测上报程序(使用Poco库的SMTPClientSession发送邮件)
- MYSQL 线程池
- python浮窗
热门文章
- 一个基于JRTPLIB的轻量级RTSP客户端(myRTSPClient)——实现篇:(五)用户接口层之提取媒体流数据
- 使用TenforFlow 搭建BP神经网络拟合二次函数
- 如何将Windows7系统中“运行”历史记录全部清除
- 2017-04-21周Java学习笔记
- SpringMVC详解(六)------与json交互
- Andrew Ng机器学习课程笔记--week2(多元线性回归&;正规公式)
- hdu3720 Arranging Your Team
- java中接口实现多态举例
- 代码精简之Lombok
- LAMP一键安装