0

寻找关于如何检测 li 是否有子 ul 或 ol 的解决方案,我发现 jquery has()非常棒,除了我需要检测是否只有实际点击的 li 有子 ol,而不是它的任何兄弟姐妹。有没有办法做到这一点?文档没有涵盖这一点。

HTML

    <ol>
    <li><a class="delete-li" href="">Page 1</a></li>
    <li><a class="delete-li" href="">Page 2</a></li>
    <li><a class="delete-li" href="">Page 3 has ol</a>
             <ol>
                <li><a class="delete-li" href="">Page 4</a></li>
                <li><a class="delete-li" href="">Page 5</a></li>
                <li><a class="delete-li" href="">Page 6</a></li>
             </ol> 
        </li>
 </ol>

JS

$('.delete-li').live('click', function(event){
event.preventDefault();
item_id = $(this).attr('rel');  
clicked = $(this);
////////////////////
    //check if has sub pages
            if(clicked.has('ol')){
              answer = confirm('This will delete all sub pages and content are you sure?');
              console.log(answer);
              if(answer===true){gogogo=true;   
                  }else{gogogo=false;}
                       }else{ gogogo=true;}
        //if yes run AJAX delete
        if(gogogo===true){
        alert('LI REMOVED');
}
////////////////

    });

签出jsfiddle的代码。

4

3 回答 3

5

has返回一个始终为 的 jQuery 对象true,因为您的处理程序绑定到a您可以使用next方法和length属性的元素:

if ( clicked.next('ol').length ) 

请注意,live不推荐使用方法,您可以改用on方法。

$(document).on('click', '.delete-li',  function (event) {
    event.preventDefault();
    var gogogo = false, $clicked = $(this), item_id = this.rel;  
    ////////////////////
    //check if has sub pages
    if ($clicked.next('ol').length) {
        gogogo = confirm('This will delete all sub pages and content are you sure?');
        // console.log(gogogo);
    }

    if (gogogo === true) {
        alert('LI REMOVED');
    }
});

http://jsfiddle.net/jMF42/

于 2013-02-05T23:24:40.400 回答
1

您正在将点击处理程序绑定到a元素。您需要参考li.

listItem = $(this).parent('li');
//check if has sub pages
if (listItem.find('ol').length) {
   ...
}

jsfiddle

于 2013-02-05T23:29:42.673 回答
0

您正在调用标签上的函数<a>,该标签没有孩子。如果你想更深入,你需要参考他的父母<li>

$('.delete-li').on('click', function (event) {
    event.preventDefault();
    $this = $(this);
    if ($this.parent('li').children('ol').length) {
        answer = confirm('This will delete all sub pages and content are you sure?');
        alert(answer);
    } else {
        alert('dont');
    }
});

http://jsfiddle.net/NGmz6/

于 2013-02-05T23:59:09.133 回答