我想备份一个html表,然后使用jquery过滤它:
$('.row').closest('td').not(':contains(' + v + ')').parent('tr').remove();由于我做了remove(),所以必须在前面备份行:
var allTable = $('#mytable').html();然后,当执行筛选时,我将返回到以前的表数据:
$('#mytable').html($(allTable));但这行不通。如果我这样做了:
alert($(allTable).filter('tr').length);在第一个赋值旁边,将返回零行。
拜托,你能帮我吗?
发布于 2012-11-06 12:36:41
filter()用于在元素数组中查找元素。这不是你需要的。您正在寻找另一个元素中的find()子元素。另外,只将HTML存储回jQuery对象是有点多余的--您可以只存储jQuery对象本身。试试这个:
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 metExample fiddle
发布于 2012-11-06 12:36:08
在使用突出显示函数时,我遇到了类似的问题。我通过将表克隆到一个隐藏的div中来解决这个问题,然后从那里恢复它,而不是从一个变量恢复它。请参阅jquery highlight() breaking in dynamic table
发布于 2014-01-07 08:38:56
你解决这个问题了吗?
我建议一个解决办法。
与其使用您的克隆表,不如创建一个(临时)表副本,并使用它进行警报。
var alertTable = allTable;
alert($(alertTable).filter('tr').length);https://stackoverflow.com/questions/13251053
复制相似问题