包含n个或更少的元素,错误的结果

时间:2014-01-09 19:49:04

标签: javascript jquery html css wordpress

我在wordpress中有下拉菜单,我有一个小问题,包裹nth(每第4个元素)li。

我的代码

<li id="item1"> ... </li>
<li id="item2"> ... </li>
<li id="item3">
    <ul class="sub-menu">
        <li> Test1</li>
        <li> Test2</li>
    </ul>
</li>
<li id="item4">
    <ul class="sub-menu">
        <li> Test3</li>
        <li> Test4</li>
        <li> Test5</li>
        <li> Test6</li>
        <li> Test7</li>
        <li> Test8</li>
        <li> Test9</li>
        <li> Test10</li>
        <li> Test11</li>
        <li> Test12</li>
    </ul>
</li>

jQuery代码

var divs = $("ul.sub-menu > li");
for(var i = 0; i < divs.length; i+=4) {
divs.slice(i, i+4).wrapAll("<div class='column'></div>");
}

我的结果(错误)

   <li id="item1"> ... </li>
   <li id="item2"> ... </li>
   <li id="item3">
       <ul class="sub-menu">
           <div class="column">
               <li> Test1</li>
               <li> Test2</li>
               <li> Test3</li>
               <li> Test4</li>
           </div>   
       </ul>
   </li>
   <li id="item4">
       <ul class="sub-menu">
           <div class="column">
               <li> Test5</li>
               <li> Test6</li>
               <li> Test7</li>
               <li> Test8</li>
           </div>   
           <div class="column">
               <li> Test9</li>
               <li> Test10</li>
               <li> Test11</li>
               <li> Test12</li>
           </div>   

       </ul>
   </li>

我尝试实现的目标:

   <li id="item1"> ... </li>
   <li id="item2"> ... </li>
   <li id="item3">
       <ul class="sub-menu">
           <div class="column">
               <li> Test1</li>
               <li> Test2</li>
           </div>   
       </ul>
   </li>
   <li id="item4">
       <ul class="sub-menu">
           <div class="column">
               <li> Test3</li>
               <li> Test4</li>
               <li> Test5</li>
               <li> Test6</li>
           </div>   
           <div class="column">
               <li> Test7</li>
               <li> Test8</li>
               <li> Test9</li>
               <li> Test10</li>
           </div>
           <div class="column">
               <li> Test11</li>
               <li> Test12</li>
           </div>   

       </ul>
   </li>

知道我做错了什么吗?这是必要的因为“item3”和“item4”是diffrents类别,并且我的代码li元素是混合的,如果在第一个ul少于4个项目

1 个答案:

答案 0 :(得分:4)

哇,你刚刚做了什么,我不知道这是可能的。 :) 无论如何:

$('.sub-menu').each(function() {
    var children = $(this).find('> li');
    for (var i = 0; i < children.length; i+=4) {
        children.slice(i, i+4).wrapAll("<div class='column'></div>");
    }
});

这将使用您尝试过的功能,但它将独立遍历每个子菜单,并且项目将被正确分组。

http://jsfiddle.net/9NUwJ/