许多关联Hidden_​​Field编辑问题。 ROR

时间:2010-01-07 01:52:29

标签: ruby-on-rails ruby arrays hidden-field

我正在尝试将数组传递给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) %>

当我提交我的编辑表单时,收到一个错误:UsersController中的ActiveRecord :: RecordNotFound #update“无法找到ID = 245的角色”

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

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

产生我认为的字符串:“role_ids”=&gt;“2,4”(必需输出:“role_ids”=&gt; [“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 个答案:

答案 0 :(得分: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"], ... }}

答案 1 :(得分:1)

接受的答案对我不起作用。如果您使用hidden_field_tag但不使用f.hidden_field,则可以使用它。我需要求助于

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

注意反向支架。

答案 2 :(得分:0)

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

答案 3 :(得分:0)

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

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

表格形式:

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

然后在更新操作中:

roles = params[:user][:role_ids].split(";")