JS如何实现动态添加的元素绑定事件

这篇文章主要介绍了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);
    }
  });

效果

JS如何实现动态添加的元素绑定事件

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容