我想从表格中选择一个tds的子集。
我事先知道索引是什么,但它们实际上是随机的(不是奇数或偶数索引等)。
例如,我想选择第0,第5和第9个td。
indexesToSelect = [0, 5, 9];
// 1) this selects the one by one
$('table td').eq(0)
$('table td').eq(5)
$('table td').eq(9)
// 2)this selects them as a group (with underscore / lodash)
var $myIndexes = $();
_.forEach(indexesToSelect, function (idx) {
$myIndexes = $myIndexes.add($('table td').eq(idx));
});
所以(2)工作,我正在使用它,但我想知道是否有更自然的方式使用jQuery。
像传递.eq()
一系列索引一样? (这不起作用)
// does not work
$('table td').eq([0, 5, 9])
如果不是,我会为.eqMulti(array)
。
注意:没有这些tds专门共享的类,因此基于类的选择将不起作用。
答案 0 :(得分:16)
我会使用.filter()
和$.inArray()
:
var elements = $("table td").filter(function(i) {
return $.inArray(i, indexesToSelect) > -1;
});
另一种[更难看的]方式是映射到选择器:
var elements = $($.map(indexesToSelect, function(i) {
return "td:eq(" + i + ")";
}).join(","), "table");
答案 1 :(得分:6)
我将VisioN的过滤方法包装到jQuery插件中:
$.fn.eqAnyOf = function (arrayOfIndexes) {
return this.filter(function(i) {
return $.inArray(i, arrayOfIndexes) > -1;
});
};
所以现在用法很干净:
var $tds = $('table td').eqAnyOf([1, 5, 9]);
答案 2 :(得分:3)
试试这个
$('table td:eq(0), table td:eq(5), table td:eq(9)')
答案 3 :(得分:2)
$('table td').filter(':eq(' + indexesToSelect.join('), :eq(') + ')')