JS获取动态添加元素的方法详解


Posted in Javascript onJuly 31, 2019

本文实例讲述了JS获取动态添加元素的方法。分享给大家供大家参考,具体如下:

在页面的渲染中,我们经常用遇到动态添加的DOM元素,那么在获取这些元素的时候或则为这些DOM元素的时候,我们有下面三种处理方法:

  • 1.  在模板引擎里面添加行内事件
  • 2.  利用事件的委托获取(常用)
  • 3.  在ajax的监听响应完成函数后面获取

一 在模板引擎里面添加行内事件

添加行内事件就是在标签里面添加事件,这样就可以直接获取到动态添加的元素.

<!-- 1.准备一个模板 -->
  <script id="tpl-table" type="text/html">
    {{ each rows value key }}
      <tr>
        <td>
            <button type="button" onclick="updateUser({{ value.id }} {{@ ','}} {{value.isDelete}})" id="btn-status" >按钮</button>
        </td>
      </tr>
    {{ /each }}
  </script>
//事件函数,书写在单独的JS文件中
  //带有参数,参数是模板传递过来的
  function updateUser (id,isDelete){
      //doSomething.........
  }

上面使用的模板是art-template,在模板里面我们给button标签注册了点击事件onclick,但是事件函数却是一个带参数的函数.当点击这个按钮的时候,就会触发点击事件,进而调用updateUser()函数.

二. 利用事件的委托获取(常用)

事件的委托可以为动态添加的元素绑定事件.

//同样以上面的代码为例,tr最后是添加到table中,那么将点击事件委托给table
$('table').on('click','tr #btn-status',function(){
    //doSomething........
})

上面的代码意思是,将点击事件绑定给table元素,但是我们点击的是table里面的button按钮,此时事件的冒泡起作用,向外冒泡遇到父元素table也有点击事件,那么就会去执行这个事件.

三 在ajax的监听响应完成函数后面获取

当我们把模板渲染出来的时候,此时页面上已经是最新的动态元素了,DOM也已经重绘完成,此时再去获取动态元素.

$.ajax({
    url : 'text.php',
    dataType : 'json',
    success : function(obj){
        //渲染动态元素到页面上
        var trHTML = template('tpl-table',obj);
        $('table').append(trHTML);
        //获取动态元素注册点击事件
        $('tr #btn-status').on('click',function(){
            //doSomething........
        });
    }
})

四 总结:

第一种方法要注意事件函数必须是全局函数;第二种最常用,但是三者的共同点都是当页面已经渲染完毕后才能获取到动态元素.

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

更多关于JavaScript相关内容可查看本站专题:《JavaScript操作DOM技巧总结》、《JavaScript页面元素操作技巧总结》、《JavaScript事件相关操作与技巧大全》、《JavaScript查找算法技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript错误与调试技巧总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
JavaScript传递变量: 值传递?引用传递?
Feb 22 Javascript
node.js Web应用框架Express入门指南
May 28 Javascript
深入理解JavaScript系列(48):对象创建模式(下篇)
Mar 04 Javascript
javascript瀑布流式图片懒加载实例解析与优化
Feb 23 Javascript
Bootstrap基本插件学习笔记之模态对话框(16)
Dec 08 Javascript
文件上传的几个示例分享【推荐】
Dec 16 Javascript
Bootstrap实现基于carousel.js框架的轮播图效果
May 02 Javascript
实例讲解Vue.js中router传参
Apr 22 Javascript
微信小程序实现循环动画效果
Jul 16 Javascript
vue 父组件通过$refs获取子组件的值和方法详解
Nov 07 Javascript
浅谈Vue 自动化部署打包上线
Jun 14 Javascript
vue3中的组件间通信
Mar 31 Vue.js
JS/jQuery实现超简单的Table表格添加,删除行功能示例
Jul 31 #jQuery
详解Vuex下Store的模块化拆分实践
Jul 31 #Javascript
ES6 Iterator接口和for...of循环用法分析
Jul 31 #Javascript
Vuex 模块化使用详解
Jul 31 #Javascript
判断“命令按钮”是否被鼠标单击详解
Jul 31 #Javascript
express框架下使用session的方法
Jul 31 #Javascript
ES6中异步对象Promise用法详解
Jul 31 #Javascript
You might like
php导入excel文件到mysql数据库的方法
2015/01/14 PHP
Thinkphp3.2.3分页使用实例解析
2016/07/28 PHP
php微信公众号开发之二级菜单
2018/10/20 PHP
避免 showModalDialog 弹出新窗体的原因分析
2010/05/31 Javascript
node.js中的console.dir方法使用说明
2014/12/10 Javascript
jquery+ajax验证不通过也提交表单问题处理
2014/12/12 Javascript
jQuery中remove()方法用法实例
2014/12/25 Javascript
jQuery大于号(&gt;)选择器的作用解释
2015/01/13 Javascript
JavaScript合并两个数组并去除重复项的方法
2015/06/13 Javascript
全面解析多种Bootstrap图片轮播效果
2016/05/27 Javascript
jQuery实现页面点击后退弹出提示框的方法
2016/08/24 Javascript
Bootstrap基本组件学习笔记之分页(12)
2016/12/08 Javascript
AngularJS基于ngInfiniteScroll实现下拉滚动加载的方法
2016/12/14 Javascript
bootstrap响应式表格实例详解
2017/05/15 Javascript
其实你可以少写点if else与switch(推荐)
2019/01/10 Javascript
如何管理Vue中的缓存页面
2021/02/06 Vue.js
[01:10:24]DOTA2-DPC中国联赛 正赛 VG vs Aster BO3 第一场 2月28日
2021/03/11 DOTA
python k-近邻算法实例分享
2014/06/11 Python
20个常用Python运维库和模块
2018/02/12 Python
python面试题Python2.x和Python3.x的区别
2019/05/28 Python
css3 按钮 利用css3实现超酷下载按钮
2013/03/18 HTML / CSS
1688平价精选商城:阿里集团旗下,工厂出厂价格直销
2017/04/24 全球购物
美国健康和保健平台:healtop
2020/07/02 全球购物
高中生期末评语
2014/01/28 职场文书
大学生军训感想
2014/02/16 职场文书
餐厅总厨求职信
2014/03/04 职场文书
幼儿园中班开学寄语
2014/04/03 职场文书
数控技校生自我鉴定
2014/04/19 职场文书
学校安全责任书范本
2014/07/23 职场文书
2015年父亲节寄语
2015/03/23 职场文书
部队2015年终工作总结
2015/04/02 职场文书
乡镇安全生产月活动总结
2015/05/08 职场文书
mysql对于模糊查询like的一些汇总
2021/05/09 MySQL
python实现股票历史数据可视化分析案例
2021/06/10 Python
js中Map和Set的用法及区别实例详解
2022/02/15 Javascript
oracle重置序列从0开始递增1
2022/02/28 Oracle