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 相关文章推荐
jQuery使用手册之一
Mar 24 Javascript
JS在TextArea光标位置插入文字并实现移动光标到文字末尾
Jun 21 Javascript
JavaScript获取按钮所在form表单id的方法
Apr 02 Javascript
jQuery插件jcrop+Fileapi完美实现图片上传+裁剪+预览的代码分享
Apr 22 Javascript
JS实现方向键切换输入框焦点的方法
Aug 19 Javascript
jQuery Validate设置onkeyup验证的实例代码
Dec 09 Javascript
iOS + node.js使用Socket.IO框架进行实时通信示例
Apr 14 Javascript
用js屏蔽被http劫持的浮动广告实现方法
Aug 10 Javascript
简单谈谈CommonsChunkPlugin抽取公共模块
Dec 31 Javascript
Vue表单控件绑定图文详解
Feb 11 Javascript
微信小程序textarea层级过高(盖住其他元素)问题的解决办法
Mar 04 Javascript
vue--vuex详解
Apr 15 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文章内容分页并生成相应的htm静态页面代码
2010/06/07 PHP
php入门学习知识点五 关于php数组的几个基本操作
2011/07/14 PHP
PHP header函数分析详解
2011/08/06 PHP
基于php-fpm的配置详解
2013/06/03 PHP
php Session存储到Redis的方法
2013/11/04 PHP
PHP多维数组排序array详解
2017/11/21 PHP
PHP实现的62进制转10进制,10进制转62进制函数示例
2019/06/06 PHP
表单类各种类型(文本框)失去焦点效果jquery代码
2013/04/26 Javascript
js禁止页面刷新禁止用F5键刷新禁止右键的示例代码
2013/09/23 Javascript
JS批量操作CSS属性详细解析
2013/12/16 Javascript
轻松学习jQuery插件EasyUI EasyUI创建树形菜单
2015/11/30 Javascript
window.open不被拦截的简单实现代码(推荐)
2016/08/04 Javascript
jquery图片放大镜效果
2017/06/23 jQuery
BetterScroll 在移动端滚动场景的应用
2017/09/18 Javascript
angularjs数组判断是否含有某个元素的实例
2018/02/27 Javascript
JavaScript 高性能数组去重的方法
2018/09/20 Javascript
JS/HTML5游戏常用算法之路径搜索算法 随机迷宫算法详解【普里姆算法】
2018/12/13 Javascript
利用Electron简单撸一个Markdown编辑器的方法
2019/06/10 Javascript
基于Vue sessionStorage实现保留搜索框搜索内容
2020/06/01 Javascript
基于vue--key值的特殊用处详解
2020/07/31 Javascript
通过实例了解Render Props回调地狱解决方案
2020/11/04 Javascript
[49:08]OpTic vs Serenity 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
python操作日期和时间的方法
2014/03/11 Python
python读取文本中的坐标方法
2018/10/14 Python
pandas把所有大于0的数设置为1的方法
2019/01/26 Python
Python爬虫爬取、解析数据操作示例
2020/03/27 Python
Pycharm无法打开双击没反应的问题及解决方案
2020/08/17 Python
接口自动化多层嵌套json数据处理代码实例
2020/11/20 Python
pyqt5实现井字棋的示例代码
2020/12/07 Python
python 统计list中各个元素出现的次数的几种方法
2021/02/20 Python
党章学习思想汇报
2014/01/14 职场文书
教师节横幅标语
2014/10/08 职场文书
继续教育心得体会(共6篇)
2016/01/19 职场文书
Python 的 sum() Pythonic 的求和方法详细
2021/10/16 Python
python工具dtreeviz决策树可视化和模型可解释性
2022/03/03 Python
详解Golang如何实现支持随机删除元素的堆
2022/09/23 Python