0

http://jsfiddle.net/Hms7Y/14/

上面的代码可以很好地根据“级别”插入项目,而无需使用任何复杂的排序算法,但是有一个问题,当没有准备好的标记时,级别 2 仍将位于级别 1 之上。

$(document).ready(function() {
  $('button').click(function() {
    var lvl = $('select').val();
    var ref = $('li.level' + lvl).last();
    var newLi =  $('<li class="level'+ lvl + '">' + lvl + ' </li>');

    console.log(ref);

    (ref.length > 0) ? newLi.insertAfter(ref) : $("ul").append(newLi);
  });
});
4

1 回答 1

0

我已经编辑了你的小提琴按你的预期工作:http: //jsfiddle.net/Hms7Y/23/

基本上我在每次点击时都添加了这个控件:

if($("ul").children().length>0){
    $("li").each(function(){
        if(lvl <= parseInt($(this).html())){
            newLi.insertBefore($(this));
        }else{
            newLi.insertAfter($(this));
        }
    });
}else{
    $("ul").append(newLi);
}
于 2013-10-18T13:37:01.883 回答