使用jQuery选择.eq()的多个元素

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用jQuery选择.eq()的多个元素相关的知识,希望对你有一定的参考价值。

我想从表中选择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没有专门共享的类,因此基于类的选择将不起作用。

答案

我会用.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");
另一答案

我将VisioN的过滤方法包装到jQuery插件中:

$.fn.eqAnyOf = function (arrayOfIndexes) {
    return this.filter(function(i) {
        return $.inArray(i, arrayOfIndexes) > -1;
    });
};

所以现在用法很干净:

var $tds = $('table td').eqAnyOf([1, 5, 9]);
另一答案

试试这个

   $('table td:eq(0), table td:eq(5), table td:eq(9)')
另一答案
$('table td').filter(':eq(' + indexesToSelect.join('), :eq(') + ')')

以上是关于使用jQuery选择.eq()的多个元素的主要内容,如果未能解决你的问题,请参考以下文章

jquery :eq选择器和eq()方法的用法与比较

通过EQ过滤删除元素不会从jQuery对象中删除该元素

jQuery元素过滤

JQuery :eq() 选择器 与 eq()遍历方法

jquery获取第几个元素的方法总结

jQuery中eq()方法用法