1

我正在尝试将数组传递给 hidden_​​field。

以下用户有 3 个角色 [2,4,5]

>> u = User.find_by_login("lesa")
=> #<User id: 5, login: "lesa", email: "lesa.beaupry@gmail.com", crypted_password: "0f2776e68f1054a2678ad69a3b28e35ad9f42078", salt: "f02ef9e00d16f1b9f82dfcc488fdf96bf5aab4a8", created_at: "2009-12-29 15:15:51", updated_at: "2010-01-06 06:27:16", remember_token: nil, remember_token_expires_at: nil>
>> u.roles.map(&:id)
=> [2, 4, 5]

用户/edit.html.erb

<% form_for @user do |f| -%>
<%= f.hidden_field :role_ids, :value => @user.roles.map(&:id) %>

当我提交我的编辑表单时,我收到一个错误:ActiveRecord::RecordNotFound in UsersController#update "Couldn't find Role with ID=245"

接下来,我尝试将 users/edit.html.erb 编辑为:

<%= f.hidden_field :role_ids, :value => @user.roles.map(&:id).join(", ") %>

产生我认为是一个字符串:“role_ids”=>“2, 4”(必需输出:“role_ids”=>[“2”,“4”])

当我尝试使用循环时:

<% for role in Role.find(:all) %>
    <%= f.hidden_field :role_ids, :value => @user.roles.map(&:id).join(",").to_a %>
    <% end %>

另一个字符串产生了:

Parameters: {"commit"=>"Update", "action"=>"update", "_method"=>"put", "authenticity_token"=>"84Fvxxo3ao8Fl+aytOFInrLatUpslfAJggleEyy4wyI=", "id"=>"5", "controller"=>"users", "user"=>{"password_confirmation"=>"[FILTERED]", "role_ids"=>"2, 4, 5", "password"=>"[FILTERED]", "login"=>"lesa", "email"=>"lesa@gmail.com"}}

有什么建议么?这一直是一个令人困惑的问题。

4

4 回答 4

1

如果您想提交一组值,我相信您可以执行以下操作:

<% @user.roles.each do |role|  %> 
  <%= f.hidden_field 'role_ids[]', :value => role.id %> 
<% end %>

然后,Rails 应该将每个具有相同名称的隐藏字段的值合并'role_ids[]'到一个数组中,从而为您提供如下内容:

Parameters: {"commit"=>"Update" ... "role_ids"=>["2", "4", "5"], ... }}
于 2010-01-07T07:31:05.397 回答
1

接受的答案对我不起作用。如果您正在使用hidden_field_tag但不能与f.hidden_field. 我需要求助于

<%= f.hidden_field 'role_ids][', value: role.id %>

注意反转的括号。

于 2011-09-14T07:35:09.367 回答
0

如果你只通过 u.roles.map(&:id)[0] 会发生什么?值 = 2?也许该值不接受多值,或者您应该传递
<%= f.hidden_​​field :role_ids, :value=>“#{u.roles.map(&:id).join(',')}">

于 2010-01-07T02:02:05.123 回答
0

您可以在控制器编辑操作(空气代码)中完成工作:

@role_ids = @user.roles.map(&:id).join(";")

在表格中:

<%= f.hidden_field, 'role_ids', :value => @role_ids %>

然后在更新操作中:

roles = params[:user][:role_ids].split(";")
于 2010-01-07T07:51:13.250 回答