忽略:http : //jsfiddle.net/gulcoza/9cVFT/1/
更新的小提琴:http : //jsfiddle.net/gulcoza/9cVFT/4/
整个代码在上面的小提琴中,但我也会在这里解释:
HTML
<ul>
<li id="e1">1</li>
<li id="e2" class="hidden">2</li>
<li id="e3">3</li>
<li id="e4" class="hidden">4</li>
<li id="e5">5</li>
<li id="e6">6</li>
<li id="e7">7</li>
<li id="e8">8</li>
<li id="e9">9</li>
<li id="e10">10</li>
</ul>
jQuery
console.log(
$('ul li:visible:nth-child(4n)')
);
我的预期结果: li#e6, li#e10
- 为什么?因为我只想要可见元素中的 4n 个元素。
但
实际结果:只有当它们可见时,我才能从 all 中获取 4n 元素。
console.log(
$('ul li:visible').filter(function(index) {
if ((index + 1) % 4 ==0) return true;
})
);
我对任何比以下更好的解决方案感兴趣:
console.log(
$('ul li:visible').filter(function(index) {
if ((index + 1) % 4 ==0) return true;
})
);
更新的小提琴:
http://jsfiddle.net/gulcoza/9cVFT/4/
为什么 4 号不起作用。在调用过滤器的那一刻,结果应该已经被过滤了,恕我直言。:|
// 4 - could be a nice solution
console.log(
$('ul li:visible').filter(':nth-child(4n)')
);
为什么这不起作用?目前$('ul li:visible')
只有可见的应该可用。