首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用jQuery为javascript变量分配和检索html表

使用jQuery为javascript变量分配和检索html表
EN

Stack Overflow用户
提问于 2012-11-06 12:27:55
回答 3查看 2.8K关注 0票数 0

我想备份一个html表,然后使用jquery过滤它:

代码语言:javascript
运行
复制
$('.row').closest('td').not(':contains(' + v + ')').parent('tr').remove();

由于我做了remove(),所以必须在前面备份行:

代码语言:javascript
运行
复制
var allTable = $('#mytable').html();

然后,当执行筛选时,我将返回到以前的表数据:

代码语言:javascript
运行
复制
$('#mytable').html($(allTable));

但这行不通。如果我这样做了:

代码语言:javascript
运行
复制
alert($(allTable).filter('tr').length);

在第一个赋值旁边,将返回零行。

拜托,你能帮我吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-11-06 12:36:41

filter()用于在元素数组中查找元素。这不是你需要的。您正在寻找另一个元素中的find()子元素。另外,只将HTML存储回jQuery对象是有点多余的--您可以只存储jQuery对象本身。试试这个:

代码语言:javascript
运行
复制
var $table = $('#mytable');
$table.remove(); // use your existing logic here
alert($table.find('tr').length);
$table.appendTo('body'); // add the table back in to the DOM when conditions are met

Example fiddle

票数 1
EN

Stack Overflow用户

发布于 2012-11-06 12:36:08

在使用突出显示函数时,我遇到了类似的问题。我通过将表克隆到一个隐藏的div中来解决这个问题,然后从那里恢复它,而不是从一个变量恢复它。请参阅jquery highlight() breaking in dynamic table

票数 0
EN

Stack Overflow用户

发布于 2014-01-07 08:38:56

你解决这个问题了吗?

我建议一个解决办法。

与其使用您的克隆表,不如创建一个(临时)表副本,并使用它进行警报。

代码语言:javascript
运行
复制
var alertTable = allTable;
alert($(alertTable).filter('tr').length);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13251053

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档