时间:2021-05-26
这篇文章主要介绍了JS如何实现动态添加的元素绑定事件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
最近做的项目要实现一个动态添加动态删除的功能,思考了一下,该怎么给动态添加的元素绑定事件。最后觉得有两种方式比较可靠,第一种是在动态添加的html代码里添加oclick事件,然后给传个唯一的参数来判断点击了哪个,然后做相应的操作,第二种是通过事件委托的原理来处理,事件委托将一个事件侦听器实际绑定到整个容器,然后在单击它时能够访问每个列表项,这种更高效一些
具体的代码实现如下:
第一:onclick
<body> <button onclick="AddJob()">添加工作经历</button> <button onclick="GetJobs()">获取全部工作</button> <div id="joblist"> <div id="job1" class="job"> <input name="CompanyName" type="text" value="公司1" /> <button onclick="DelJob(1)">删除</button> </div> </div> <script type="text/javascript"> //添加工作经历 function AddJob() { var timestamp = parseInt((new Date()).valueOf()); //唯一的标识 console.log(parseInt((new Date()).valueOf())); document.getElementById("joblist").innerHTML += `<div id="job` + timestamp + `" class="job"> <input name="CompanyName" type="text" value="公司` + timestamp + `" /> <button onclick="DelJob(` + timestamp + `)">删除</button> </div>`; } //删除工作经历 function DelJob(timestamp) { document.getElementById("job" + timestamp).remove(); } //获取全部工作经历 function GetJobs() { var jobs = document.getElementsByClassName("job"); var arr = []; for (var i = 0; i < jobs.length; i++) { var job = jobs[i]; var companyName = job.children[0].value; arr.push(companyName); } console.log(arr); alert(arr); } </script></body>第二种:
document.getElementById('joblist').addEventListener('click', function (ev) { var target = ev.target || ev.srcElement; if (target.nodeName.toLowerCase() == 'button') { var e = document.getElementById(target.parentNode.id); document.getElementById("joblist").removeChild(e); } });效果
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了JS实现为动态创建的元素添加事件操作。分享给大家供大家参考,具体如下:html中直接生成的元素,添加事件,我们都知道,但是如何为一个动态生成的元素
其所谓的动态添加事件实质就是指js中的事件委托。我们知道在js中,事件处理只能绑定在当前被选中的元素上,换句话也就是说,事件处理只能绑定在当前文档已经存在的元素
给动态添加的元素添加js事件,不能直接添加js事件,需要借助on()方法,给选择器指定的子元素添加事件处理函数,并非选择器本身;1.语法$(selector).
在实际开发中会遇到要给动态生成的html元素绑定触发事件的情况:假设我们要给ul动态添加的绑定click事件形成如下结果applepearfunctiontes
最近项目中要要到js动态给给元素绑定事件,刚好之前没用到过这些,顺便学习一下,于是google了一下事件,写了如下两个事件一个添加事件,一个是移除事件/addE