页面上可以动态添加数据,比如table,点击按钮可以动态添加行,下面与大家分享下jQuery如何获取动态生成的元素
需求描述:页面上可以动态添加数据,比如table,点击按钮可以动态添加行。又或页面
加载时table数据是通过ajax从后台获取的。而这时我们想要获取其中的某个值,又该如何获取呢?

如果是要通过某个事件来获取的比如click,mouseover等等,则可以使用live()方法
 
$(".button").live("click",function(){
console.info($("#mytd").html());
})

而如果不是通过某个事件,当页面加载的时候我们就要获取值或进行其他操作

live()方法就不行了,因为我们无法传入一个事件。

比如以下代码:
 
<body>
<table id="tab" border="1" width="30%">

</table>
</body>
<script type="text/javascript">
$(function() {
$.post("admin/UserForumthemeBabygrowupFrontList.do",{},function(data){
console.info(data.table);
$("#tab").append(data.table);
})

alert($("#mytd").html()); //获取值
});
</script>

以上代码很简单,就是通过post从后台返回的值添加到<table>中

后台返回数据为 <tr><td id='mytd'>北京</td><td>深圳</td></tr>而我们要在post之后获取id为mytd的值,

此时是获取不到的,我们从浏览器中就可以观察出问题:
 
从以上可以看出在alert的时候 数据并还没有加载出来 控制台也并没有打印出信息,所以此时是取不到数据的。

使用ajaxComplete()方法可以在请求完成时运行要执行的代码,我们修改为如下:
 
$(function() {
$.post("admin/UserForumthemeBabygrowupFrontList.do",{},function(data){
console.info(data.table);
$("#tab").append(data.table);
})
$("#tab").ajaxComplete(function(){ //待请求完成时 执行
alert($("#mytd").html());
})
});

 
此时再获取的时候页面已加载完数据。
最新资讯
陌陌:总裁兼COO王力接替创始人唐岩担任公司新任CEO

陌陌:总裁兼COO王力接

新浪科技获悉,陌陌今日通过一项人事任命:总裁兼首席运营
高价苹果手机未阻挡中国消费者 中国成全球最大高端智能手机市场

高价苹果手机未阻挡中

研究机构Canalys数据显示,中国已经成为了全球最大的高
再表态!德国经济部长:我不反对华为

再表态!德国经济部长:我

在被问及“在5G移动网络扩张方面排挤中国华为是否会导
新东方通过聆讯:第一财季营收下滑8% 俞敏洪持股12.3%

新东方通过聆讯:第一财

根据招股书,俞敏洪持有公司1975万股公司股份,持股占比12
美监管机构回应特斯拉在中国被召回:尚未收到相关重大投诉

美监管机构回应特斯拉

美国国家公路交通安全管理局(NHTSA)当地时间周五下午表
苹果副总裁承认iPhone 12会让部分卡片消磁:建议用卡包保护

苹果副总裁承认iPhone

在MagSafe磁吸无线充电方面,一些用户担心iPhone 12背部
最新文章
详解Vue的ref特性的使用

详解Vue的ref特性的使

这篇文章主要介绍了详解Vue的ref特性的使用,文中通过
vue学习笔记之slot插槽基本用法实例分析

vue学习笔记之slot插

这篇文章主要介绍了vue学习笔记之slot插槽基本用法,结
vue跳转方式(打开新页面)及传参操作示例

vue跳转方式(打开新页

这篇文章主要介绍了vue跳转方式(打开新页面)及传参操作,
vue学习笔记之过滤器的基本使用方法实例分析

vue学习笔记之过滤器

这篇文章主要介绍了vue学习笔记之过滤器的基本使用方
js获取本日、本周、本月的时间代码

js获取本日、本周、本

本篇文章给大家分享的内容是利用js如何获取本日、本周
node crawler如何添加promise支持

node crawler如何添加

这篇文章主要介绍了node crawler如何添加promise支持,