我看过this这似乎对我的代码没有任何影响。 我试过this似乎只影响第一个复选框,但是当我再次点击它时不会取消选中复选框.... 我还看到了其他一些方法,我不确定是否完全是Rails-esque(或任何术语应该是)。
那么,有人可以指出我正确的方向吗?
以下是我的观点:
<%= render 'admin/distributions/head' %>
<% title 'Workflow' %>
<%= form_for @search, :url => url_for(:controller => params[:controller], :action => params[:action]), :html => {id => "distribution_workflow",:method => :get} do |f| %>
<div class="opportunity-block yellow">
<div class="form-block mrl mbm">
<%= f.label :created_at_gt, "Created at >" %>
<%= f.text_field :created_at_gt, :class => "js-db-date-picker" %>
</div>
<div class="form-block mrl mbm">
<%= f.label :created_at_lte, "Created at <=" %>
<%= f.text_field :created_at_lte, :class => "js-db-date-picker" %>
</div>
<div class="form-block mrl mbm mtm">
<%= f.label :status_equal, "Status" %>
<%= f.select :status_equal, %w(delivered no_success already_registered qa_complete success follow_up), :include_blank => " " %>
</div>
<div class="clear"></div>
<%= submit_tag 'Apply Filter', :class => "input-button dark unit-right mrl" %>
<div class="clear"></div>
</div>
<% end %>
<%= form_tag edit_multiple_admin_distributions_workflows_path , :id => "workflow_form" do %>
<%= submit_tag "Edit Selected" %>
<table class="standard-grid">
<tr>
<th class="first"> </th>
<th>ID</th>
<th>Customer</th>
<th>Resume URL</th>
<th>Partner</th>
<th>Status</th>
<th>Assigned To</th>
<th>Comments</th>
</tr>
<% @report.each do |distribution| %>
<tr>
<td><%= check_box_tag "distribution_ids[]", distribution.id %></td>
<td>
<%= distribution.owner.id %>
</td>
<td>
<%=link_to distribution.owner.full_name, "mailto:#{distribution.owner.email}" %>
</td>
<td>
<a href=<% UrlService.download_blob_url(distribution.resume) %>>Resume URL</a>
</td>
<td>
<%=link_to distribution.matching_profile.partner.title, "mailto:#{distribution.matching_profile.partner.email}" %>
</td>
<td>
<%= distribution.status %>
</td>
<td>
<%= distribution.assignee_id ? User.find(distribution.assignee_id).full_name : " " %>
</td>
<td>
<%= distribution.comments %>
</td>
</tr>
<% end %>
</table>
<% end %>
答案 0 :(得分:21)
以下是适合您的工作示例:http://jsfiddle.net/wYPWL/
HTML示例:
<input type="checkbox" id="selectAll" value="selectAll"> Select / Deselect All<br/><br/>
<input type="checkbox" name="foo" value="bar1"> Bar 1<br/>
<input type="checkbox" name="foo" value="bar2"> Bar 2<br/>
<input type="checkbox" name="foo" value="bar3"> Bar 3<br/>
<input type="checkbox" name="foo" value="bar4"> Bar 4<br/>
使用Javascript:
$('#selectAll').click(function() {
if (this.checked) {
$(':checkbox').each(function() {
this.checked = true;
});
} else {
$(':checkbox').each(function() {
this.checked = false;
});
}
});
无论您的复选框名称是什么,这都会有效。如果您真的只想定位上面代码中显示的复选框,可以将$(':checkbox')
替换为$('input[id^="distribution_ids"]')
,这是jQuery定位ID为 distribution_ids 强>
答案 1 :(得分:2)
如果使用jquery,您可以使用以下(coffeeScript):
if (this.checked)
$(':checkbox').each ->
$(this).prop('checked', true)
else
$(':checkbox').each ->
$(this).prop('checked', false)
我发现尝试设置this.checked = false时出现问题 - 不确定发生了什么,但上面的代码有效。
答案 2 :(得分:1)
我发现 iWasRobbed 的问题是,如果选中了Select All
,那么如果您取消选中任何一个选项({{1} },Bar1
,Bar2
)然后Bar3
必须取消选中...
这是解决方案..
HTML代码
Select All
JavaScript代码:
<input id="campaign_range_ids_1" class="checkbox" type="checkbox" value="1" name="campaign[range_ids][]"> India
<input id="campaign_range_ids_2" class="checkbox" type="checkbox" value="2" name="campaign[range_ids][]"> London
<input id="campaign_range_ids_3" class="checkbox" type="checkbox" value="3" name="campaign[range_ids][]"> USA
<input id="campaign_range_ids_4" class="checkbox" type="checkbox" value="4" name="campaign[range_ids][]"> All
答案 3 :(得分:0)
如果您要为同一页面上的多个单独列表全选
$("input[data-select-all]").on("click", function() {
let $checkboxes = $("input[data-"+$(this).data("select-all")+"]");
if (this.checked) {
$checkboxes.each(function() {
this.checked = true;
});
} else {
$checkboxes.each(function() {
this.checked = false;
});
}
});
<table>
<thead>
<tr>
<th><input type="checkbox" name="selected" id="select-all" value="1" title="Select all" data-select-all="select-all-target"></th>
<th>Asset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><span class="form-check"><input type="checkbox" name="selected" id="asset_type_11" value="1" data-select-all-target="true"></span></td>
<td>The name</td>
<td>The description</td>
</tr>
</tbody>
</table>