我有一个属于个人资料模型的工作模型。配置文件has_many工作。我有一个嵌套的模型表单,用户可以在其中添加作业。表单已成功添加作业,但编辑/更新无效。相反,当我尝试编辑作业时,它会保留旧版本的作业,但也会添加新版本。它不会用新版本替换旧版本。我该如何解决?我很确定它与编辑/更新控制器有关。
编辑控制器:
def edit
@profile = current_user.profile
end
更新控制器:
def update
#if current_user.profile.jobs.any?
@profile = current_user.profile.update_attributes(profile_params)
if current_user.profile.invalid?
@profile = current_user.profile
render :edit, :status => :unprocessable_entity
else
redirect_to profile_path(current_user.profile_name)
end
end
问题是,更新控制器正在处理非嵌套信息,它只适用于嵌套作业。以下是强大的参数:
def profile_params
params.require(:profile).permit(:title,
:category, :description, :state, :zip_code, :rate,
jobs_attributes: [:firm, :position, :category, :description,
:begin, :end, :_destroy])
end
以下是个人资料模型:
class Profile < ActiveRecord::Base
belongs_to :user
has_many :jobs
accepts_nested_attributes_for :jobs , :reject_if => :all_blank, :allow_destroy => true
end
此外,这是我的路线,如果这将有所帮助:
resources :profiles do
resources :jobs
end
提前感谢您的帮助。
修改
以下是创建动作中的参数:
{"jobs_attributes"=>{"1383593195849"=>{"firm"=>"1st firm", "position"=>"1st position",
"category"=>"1st category", "description"=>"1st description", "begin"=>"1999",
"end"=>"1999", "_destroy"=>"false"}}}
以下是更新后同一工作的参数:
{"jobs_attributes"=>{"0"=>{"firm"=>"1st firm", "position"=>"1st position",
"category"=>"1st category", "description"=>"1st description", "begin"=>"1999",
"end"=>"1999", "_destroy"=>"false"}, "1"=>{"firm"=>"1st firm",
"position"=>"1st position", "category"=>"1st category",
"description"=>"1st description", "begin"=>"1999", "end"=>"1999", "_destroy"=>"1"}}}
编辑:
以下是我的观点。我不认为他们是问题的一部分。
= simple_form_for @profile do |f|
%h3 Jobs
#jobs
= f.simple_fields_for :jobs do |job|
= render 'job_fields', :f => job
.links
= link_to_add_association 'add job', f, :jobs
= f.submit
以下是“job_fields”部分:
.nested-fields
= f.input :firm
= f.input :position
= f.input :category
= f.input :begin
= f.input :end
= f.input :description
= f.input :_destroy, as: :boolean, inline_label: 'Delete box'
= link_to_remove_association "remove task", f
答案 0 :(得分:8)
诀窍是将':id'符号添加到强params。虽然我还没弄清楚为什么,我不确定它是否安全。