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 相关文章推荐
js 禁用浏览器的后退功能的简单方法
Dec 10 Javascript
jquery改变disabled的boolean状态的三种方法
Dec 13 Javascript
JS清空多文本框、文本域示例代码
Feb 24 Javascript
jQuery实现div随意拖动的实例代码(通用代码)
Jan 28 Javascript
AngularJS ng-app 指令实例详解
Jul 30 Javascript
JS动态遍历json中所有键值对的方法(不知道属性名的情况)
Dec 28 Javascript
基于jQuery选择器之表单对象属性筛选选择器的实例
Sep 19 jQuery
基于vue-cli 打包时抽离项目相关配置文件详解
Mar 07 Javascript
Taro集成Redux快速上手的方法示例
Jun 21 Javascript
纯js+css实现在线时钟
Aug 18 Javascript
JS数组转字符串实现方法解析
Sep 04 Javascript
JavaScript原生数组函数实例汇总
Oct 14 Javascript
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+Mysql+jQuery实现动态展示信息
2011/10/08 PHP
php实现有趣的人品测试程序实例
2015/06/08 PHP
CodeIgniter框架基本增删改查操作示例
2017/03/23 PHP
TP5多入口设置实例讲解
2020/12/15 PHP
在图片上显示左右箭头类似翻页的代码
2013/03/04 Javascript
js调试系列 控制台命令行API使用方法
2014/06/18 Javascript
基于JS实现新闻列表无缝向上滚动实例代码
2016/01/22 Javascript
纯js实现悬浮按钮组件
2016/12/17 Javascript
详解vue.js移动端导航navigationbar的封装
2017/07/05 Javascript
使用bootstraptable插件实现表格记录的查询、分页、排序操作
2017/08/06 Javascript
浅谈react-native热更新react-native-pushy集成遇到的问题
2017/09/30 Javascript
详解JSONObject和JSONArray区别及基本用法
2017/10/25 Javascript
vue 中directive功能的简单实现
2018/01/05 Javascript
在vue项目中使用md5加密的方法
2018/09/14 Javascript
js回文数的4种判断方法示例
2019/06/04 Javascript
微信小程序实现单个卡片左滑显示按钮并防止上下滑动干扰功能
2019/12/06 Javascript
ReactRouter的实现方法
2021/01/25 Javascript
[01:57]2018DOTA2亚洲邀请赛赛前采访-iG
2018/04/03 DOTA
跟老齐学Python之大话题小函数(1)
2014/10/10 Python
Python中尝试多线程编程的一个简明例子
2015/04/07 Python
python数据处理 根据颜色对图片进行分类的方法
2018/12/08 Python
python分布式编程实现过程解析
2019/11/08 Python
python3用PyPDF2解析pdf文件,用正则匹配数据方式
2020/05/12 Python
python 负数取模运算实例
2020/06/03 Python
Python 如何测试文件是否存在
2020/07/31 Python
使用HTML5在网页中嵌入音频和视频播放的基本方法
2016/02/22 HTML / CSS
英国老牌潮鞋店:Offspring
2019/08/19 全球购物
德国BA保镖药房中文网:Bodyguard Apotheke
2021/03/09 全球购物
海量信息软件测试笔试题
2015/08/08 面试题
学生会离职感言
2014/02/11 职场文书
阳光体育活动实施方案
2014/05/25 职场文书
作息时间调整通知
2015/04/22 职场文书
股东大会通知
2015/04/24 职场文书
学习杨善洲同志先进事迹心得体会
2016/01/23 职场文书
《索溪峪的野》教学反思
2016/02/19 职场文书
MySQL分区表实现按月份归类
2021/11/01 MySQL