【发布时间】:2019-06-10 09:45:56
【问题描述】:
如何从散列的enum 创建collection_check_boxes:
class User < ApplicationRecord
has_many :roles, dependent: :destroy
accepts_nested_attributes_for :roles, allow_destroy: true
end
class Role < ApplicationRecord
belongs_to :user
enum permission: {
read_contact: 0,
write_contact: 1,
read_message: 2,
write_message: 3
}
end
我尝试了很多方法:
= form_for(@user) do |f|
= f.collection_check_boxes :permissions, Role.permissions, :last, :first
= f.submit class: "button"
我收到了undefined method permissions for #<User:0x00007...>
如果我尝试:
= form_for(@user) do |f|
= f.collection_check_boxes :roles, Role.permissions, :last, :first
= f.submit class: "button"
用户控制器:
def update
@user = User.new(user_params)
if @user.save
...
end
def user_params
params.require(:user).permit(:roles)
end
我收到了Unpermitted parameter: :roles
尽管查看参数:
Parameters: {"utf8"=>"✓", "authenticity_token"=>"...", "user"=>{"roles"=>["", "1", "2"]}, "commit"=>"Update", "id"=>"3"}
这也是检查创建,如何取消检查删除?
更新:试试@Steve 说我应该使用嵌套表单
= form_for(@user) do |f|
= f.fields_for :roles do |ff|
= ff.collection_check_boxes :permission, Role.permissions, :first, :first
= f.submit class: "button"
我从数据库中获得了正确的检查权限!耶!!
但是在发送表单时,这是参数:
Parameters: {"utf8"=>"✓", "authenticity_token"=>"...", "user"=>{"roles_attributes"=>{"0"=>{"permission"=>["", "read_message", "write_message"], "id"=>"18"}}}, "commit"=>"Update", "id"=>"3"}
我得到了Unpermitted parameter: :permission 虽然我在控制器中允许它:
def user_params
params.require(:user).permit(roles_attributes: %i[id permission _destroy])
end
我认为参数应该是这样的:
params = { user: {
roles_attributes: [
{ permission: 'read_message' },
{ permission: 'write_message' },
...
]
}}
相反,我现在在 params 中得到了什么:
params = { user: {
roles_attributes: [
{ permission: ['', 'read_message', 'write_message' }
...
]
}}
【问题讨论】:
标签: ruby-on-rails enums form-for