2014-11-04 70 views
2

我想刪除在jQuery中選中的複選框,但是當我想獲取複選框的狀態時我收到錯誤消息。刪除在jQuery中選中的複選框

jsfiddle

<div class="control-group"> 

<label class="checkbox"><input value="0" type="checkbox">Message 0</label> 
<label class="checkbox"><input value="1" type="checkbox">Message 1</label> 
<label class="checkbox"><input value="2" type="checkbox">Message 2</label> 
<label class="checkbox"><input value="3" type="checkbox">Message 3</label> 
<label class="checkbox"><input value="4" type="checkbox">Message 4</label> 
<label class="checkbox"><input value="5" type="checkbox">Message 5</label> 
<label class="checkbox"><input value="6" type="checkbox">Message 6</label> 
<label class="checkbox"><input value="7" type="checkbox">Message 7</label> 
<label class="checkbox"><input value="8" type="checkbox">Message 8</label> 

</div> 


<button class="btn" type="button" id="deleteAcc">Delete</button> 

我jQuery代碼是:

$("#deleteAcc").on("click",function(){  
    $(".control-group label.checkbox").each(function(){ 
     if (this.children(":first").is(':checked')) { 
      this.remove(); 
     } 
    }); 
}); 
+0

你可以使用'如果(this.children .checked [0])this.parentNode .removeChild(這個)'。 – RobG 2014-11-04 09:52:45

回答

5

你不需要each方法。只要選擇檢查輸入和刪除父母(含有對應的複選框的標籤的元素):

$("#deleteAcc").on("click", function() { 
 
    $(".checkbox input:checked").parent().remove(); 
 
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<div class="control-group"> 
 

 
    <label class="checkbox"> 
 
    <input value="0" type="checkbox">Message 0</label> 
 
    <label class="checkbox"> 
 
    <input value="1" type="checkbox">Message 1</label> 
 
    <label class="checkbox"> 
 
    <input value="2" type="checkbox">Message 2</label> 
 
    <label class="checkbox"> 
 
    <input value="3" type="checkbox">Message 3</label> 
 
    <label class="checkbox"> 
 
    <input value="4" type="checkbox">Message 4</label> 
 
    <label class="checkbox"> 
 
    <input value="5" type="checkbox">Message 5</label> 
 
    <label class="checkbox"> 
 
    <input value="6" type="checkbox">Message 6</label> 
 
    <label class="checkbox"> 
 
    <input value="7" type="checkbox">Message 7</label> 
 
    <label class="checkbox"> 
 
    <input value="8" type="checkbox">Message 8</label> 
 

 
</div> 
 

 

 
<button class="btn" type="button" id="deleteAcc">Delete</button>

1

的實際問題是,在$.each閉合的this上下文是對DOM節點的引用本身。您可以通過包裝解決這個問題的方法之一this$

$("#deleteAcc").on("click",function(){ 
    $(".control-group label.checkbox").each(function(){ 
     if ($(this).children(":first").is(':checked')) { 
      $(this).remove(); 
     } 
    }); 
}); 
+0

^你說得對。將更新我的答案。 – Vinay 2014-11-04 09:14:27

0

試試這個 http://jsfiddle.net/zp3vwh1j/2/

$("#deleteAcc").on("click",function(){ 
    $("input:checkbox").each(function() { 
     if ($(this).is(":checked")) { 
      $(this).parent().remove(); 
     } 
    }); 
}); 
0
$().ready(function() { 
    $('body').on('click', '#deletebtn', function() { 

     $("#example1 tr").each(function() { 
      var rowSelector = $(this); 
      if (rowSelector.find("input[type='checkbox']").prop('checked')) 
      { 
       //THE MARKUP SHOWING THE ID IS NOT AVAILABLE 
       //POST A TABLE ENTRY TO CLEAR UP 
       var id = rowSelector.find('td').first().next().html(); 
       var sendObj = {Id : id}; 
       //USE JSON OBJECT 
       $.ajax({ 
        url : "/page.aspx/deleteRecord",//CHANGE TO YOUR URL 
        dataType: "json", 
        data: sendObj, 
        type: "POST", 
        success: function() { 
         alert("entry deleted"); 
        } 
       }); 
       rowSelector.remove(); 
      } 
     }); 

    }); 
}); 
+0

這個答案會受益於一些解釋,而不是隻發佈代碼。例如這種方法與原始海報已經嘗試的方式有何不同。 – 2017-01-09 14:59:14