gpt4 book ai didi

javascript - 使用 '.each' 方法 : how do I get the indexes of multiple ordered lists to each begin at [0]?

转载 作者:行者123 更新时间:2023-11-29 18:36:32 26 4
gpt4 key购买 nike

我有多个 div,每个都有一个有序列表(各种长度)。我正在使用 jquery 根据其索引向每个列表项添加一个类(为了对每个列表的部分进行列化)。到目前为止我所拥有的...

<script type="text/javascript">

/* Objective: columnize list items from a single ul or ol in a pre-determined number of columns
1. get the index of each list item
2. assign column class according to li's index
*/
$(document).ready(function() {

$('ol li').each(function(index){
// assign class according to li's index ... index = li number -1: 1-6 = 0-5; 7-12 = 6-11, etc.
if ( index <= 5 ) {
$(this).addClass('column-1');
}
if ( index > 5 && index < 12 ) {
$(this).addClass('column-2');
}
if ( index > 11 ) {
$(this).addClass('column-3');
}

// add another class to the first list item in each column
$('ol li').filter(function(index) {
return index != 0 && index % 6 == 0;
}).addClass('reset');

}); // closes li .each func
}); // closes doc.ready.func

</script>

...如果只有一个列表则成功;当有其他列表时,最后一个列类(“column-3”)将添加到页面上所有剩余的列表项中。换句话说,脚本目前正在通过所有后续列表/列表项连续索引,而不是为每个有序列表重新设置为 [0]。

有人可以告诉我正确的方法/语法来更正/修改它,以便脚本重新寻址/索引每个有序列表吗?

非常感谢。

谢基

附注标记非常简单:

<div class="tertiary">
<h1>header</h1>
<ol>
<li><a href="#" title="a link">a link</a></li>
<li><a href="#" title="a link">a link</a></li>
<li><a href="#" title="a link">a link</a></li>
</ol>
</div><!-- END div class="tertiary" -->

最佳答案

这将遍历每个 OL,但一次一次:

// loop over each <ol>
$('ol').each(function(olIndex){

// loop over each <li> within the given <ol> ("this")
$(this).find('li').each(function(liIndex){
// do your <li> thing here with `liIndex` as your counter
});

});

至于中间的所有东西,您可以使用一些更好的选择器来改进它:

$('ol').each(function(){

$(this).find('li')

.filter(':lt(6)').addClass('column-1') // <li> 1-5
.filter(':first').addClass('reset').end().end() // <li> 1
.filter(':gt(5):lt(12)').addClass('column-2') // <li> 6-11
.filter(':first').addClass('reset').end().end() // <li> 6
.filter(':gt(11)').addClass('column-3') // <li> 12+
.filter(':first').addClass('reset'); // <li> 12

});

当然,如果我们在这里制作列,也许我们应该动态获取这些计数?

$('ol').each(function(){

var $lis = $(this).find('li');
var len = $lis.size();
var colLen = Math.ceil(count / 3);

// and so on with the filter stuff with

});

关于javascript - 使用 '.each' 方法 : how do I get the indexes of multiple ordered lists to each begin at [0]?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2615758/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com