どこかに単純なエラーがあるような気がしますが、私の人生ではそれを見つけることができません。私はフィルター モデルを持っています。その _form.html.erb には、さまざまな選択とコレクションの選択があります。送信ボタンをクリックすると、コントローラー内でデバッガーを使用したところ、いくつかの選択ボックスの値がパラメーターに送信されていないことがわかりました。ボタンやその他の無関係なものを取り除いたコードを次に示します。
<%= simple_form_for(@filter) do |f| %>
<div class="inputs">
<%= f.input :name %>
<%= f.input :scope, :collection => ["Global", "Group", "Private"], :include_blank => false %><br>
<p style="margin-left:190px;"><b>Users:</b></p>
<div style="float: left; width: auto; margin-left: 190px;">
<%= collection_select(:user, :id, User.all, :id, :full_name, {}, {:multiple => true, :size => 10}) %>
</div>
<%= select(:selected_users, :id, [], {}, {:size => 10, :style => "width:160px;", :multiple => true}) %>
<p style="margin-left:190px;"><b>Positions:</b></p>
<div style="float: left; width: auto; margin-left: 190px;">
<%= collection_select(:position, :id, Position.all, :id, :name, {}, {:size => 10, :multiple => true}) %>
</div>
<div style="float: left; width: auto; margin-left: 60px; margin-top: -120px;">
<%= collection_select(:selected_positions, :id, [], :id, :name, {}, {:size => 10, :style => "width:160px;", :multiple => true}) %>
</div>
<p style="margin-left:190px;"><b>States:</b></p>
<%= select("selected_statuses", "status", ["Approved", "Pending", "Deny"], {}, {:multiple => true, :size => 3, :style => "margin-left:190px;"})%>
</div>
<% end %>
私のパラメータでは、[:filter][:scope]、[:filter][:name]、[:user][:id]、[:position][:id]、および [:selected_statuses][:status] を取得します。 、しかし残りのどれも。選択したステータスの選択が機能しているのに、選択したユーザーの選択が機能していないのはなぜですか? または、位置 collection_selects の 1 つですが、他の位置ではありませんか? 私はとても混乱しています。また、問題があれば、selected_users と selected_positions が空白になっているのは、オプションが JavaScript で追加されているためです。
EDIT:javascriptの後、HTML(不要なビットは省略されています)は
<div class="inputs">
<div class="input string optional">
<label class="string optional" for="filter_name"> Name</label>
<input id="filter_name" class="string optional" type="text" size="50" name="filter[name]" maxLength="255">
</div>
<div class="input select optional">
<label class="select optional" for="filter_scope"> Scope</label>
<select id="filter_scope" class="select optional" name="filter[scope]">
<option value="Global">Global</option>
<option value="Private">Private</option>
</select>
</div>
<p style="margin-left:190px;">
<b>Users:</b>
</p>
<div style="float: left; width: auto; margin-left: 190px;">
<select id="user_id" size="10" name="user[id][]" multiple="multiple">
<option value="2">Ethan Webworm</option>
<option value="3">Matthew Barkbeetle</option>
<option value="4">Sara Caterpillar</option>
<option value="5">Olivia Daggermoth</option>
</select>
</div>
<select id="selected_users_id" style="width:160px;" size="10" name="selected_users[id][]" multiple="multiple">
<option value="2">Ethan Webworm</option>
<option value="3">Matthew Barkbeetle</option>
<option value="4">Sara Caterpillar</option>
</select>
<div style="float:left; width:auto; margin-left: 190px;>
<select id="position_id" size="10" name="position[id][]" multiple="multiple">
<option value="1">Manager</option>
<option value="2">CEO</option>
<option value="3">VP</option>
</select>
</div>
<div style="float: left; width: auto; margin-left: 60px; margin-top: -120px;">
<select id="selected_positions_id" style="width:160px;" size="10" name="selected_positions[id][]" multiple="multiple">
<option value="1">Manager</option>
</select>
</div>
<select id="selected_statuses_status" style="margin-left:190px;" size="3" name="selected_statuses[status][]" multiple="multiple">
<option value="Approved">Approved</option>
<option value="Pending">Pending</option>
<option value="Deny">Deny</option>
</select>
</div>