jQuery - 切换选择所有复选框

use*_*124 23 checkbox jquery

与一堆示例进行了斗争,并且仍然是jQuery/Javascript的新手,无法让我的代码运行(这里是我在gsp中的模板):

<table>
    <thead>
    <tr>
       <th><input type="checkbox" name="selectAll" onclick="selectAll(this.checked);"/></th>
    </tr>
    </thead>
    <tbody>
         <td>
            <td><input type="checkbox" name="domainList" value="${domainInstance.id}"/></td>
    </tbody>
<table>
Run Code Online (Sandbox Code Playgroud)

我在我的主gsp中有以下javascript片段,它调用模板:

function selectAll(status) {

}
Run Code Online (Sandbox Code Playgroud)

如何从selectAll名称中选择所有复选框?

Sel*_*gam 63

由于您使用的是jQuery,因此您应该onclick为selectAll 使用如下所示的处理程序.

$(':checkbox[name=selectAll]').click (function () {
  $(':checkbox[name=domainList]').prop('checked', this.checked);
});
Run Code Online (Sandbox Code Playgroud)

请注意,上面的代码将查看整个dom的复选框,name=selectAll并设置复选框的状态name=domainList.

下面是一个稍微好一点的版本,带有较小的标记更改,

jsFiddle DEMO

$('#selectAllDomainList').click(function() {
  var checkedStatus = this.checked;
  $('#domainTable tbody tr').find('td:first :checkbox').each(function() {
    $(this).prop('checked', checkedStatus);
  });
});
Run Code Online (Sandbox Code Playgroud)
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<table id="domainTable">
  <!-- Added ID -->
  <thead>
    <tr>
      <th>
        <!-- Added ID to below select box -->
        <input type="checkbox" name="selectAll" id="selectAllDomainList" />
      </th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>
        <input type="checkbox" name="domainList" value="${domainInstance.id}" />
      </td>
    </tr>
    <tr>
      <td>
        <input type="checkbox" name="domainList" value="${domainInstance.id}" />
      </td>
    </tr>
    <tr>
      <td>
        <input type="checkbox" name="domainList" value="${domainInstance.id}" />
      </td>
    </tr>
    <tr>
      <td>
        <input type="checkbox" name="domainList" value="${domainInstance.id}" />
      </td>
    </tr>
  </tbody>
  <table>
Run Code Online (Sandbox Code Playgroud)


Ray*_*Ray 6

$("input:checkbox").prop("checked", status);
Run Code Online (Sandbox Code Playgroud)