我有3个模型。用户,简历和语言。用户有一个简历。简历有很多语言。用户通过其简历具有多种语言。当我尝试保存表格时,我会发现该语言没有用户ID的错误。如何使用户ID通过我的形式通过简历和语言?
CV正正确接收用户ID。语言不是。
我正在使用简单形式和茧宝石。
形式的简化版本
= simple_form_for(@cv, url: user_cvs_path) do |f|
= f.simple_fields_for :languages do |language|
来自用户模型
has_one :cv, dependent: :destroy
has_many :languages, through: :cv, inverse_of: :user
来自CV模型
belongs_to :user
has_many :languages, dependent: :destroy
accepts_nested_attributes_for :languages, allow_destroy: true
来自语言模型
belongs_to :user
belongs_to :cv
来自简历控制器
before_action :set_user
def new
@cv = @user.build_cv
@cv.languages.build
end
def create
@cv = @user.create_cv(cv_params)
respond_to do |format|
if @cv.save
format.html { redirect_to user_cv_url(@user, @cv), notice: 'Cv was successfully created.' }
format.json { render :show, status: :created, location: @cv }
else
format.html { render :new }
format.json { render json: @cv.errors, status: :unprocessable_entity }
end
end
end
def cv_params
params.require(:cv).permit(
:user_id,
:first_name,
:middle_name,
:last_name,
... # lots of params left out for brevity
languages_attributes: [
:id,
:cv_id,
:user_id,
:name,
:read,
:write,
:speak,
:listen,
:_destroy])
end
def set_user
@user = current_user if user_signed_in?
end
您的语言模型不需要belongs_to :user
。语言属于CV,而CV属于用户,因此语言和用户之间的关系已经到位。如果您需要访问用户的特定语言,则可以编写@language.cv.user
要解决您的问题,只需删除anders_to:从语言模型中删除用户,从语言中删除user_id,然后从语言表中删除user_id。