2

我有两个独立的“组件”模型、联系人和文章。联系人有多种类型(生产商、出口商等)。

在新的文章表单中,我有一个带有联系人(id 和标题)的下拉选择器,并且希望将选定的值和文本存储在文章表中。

在新文章表单视图中:

<%= f.select :producer_id, options_for_select(producers, @article.producer_id) %>

这有效并producer_id存储在文章表中。

这对我来说很清楚和合乎逻辑,但在某些情况下,我还需要将所选联系人的标题存储在producer_title.

我已经阅读了许多不同的选项,例如“在模型中执行,保存前”或“在控制器中执行”,并且我已经在控制器中完成了。

文章控制器(仅更新的一部分):

#cont_name is producer title from Contacts
def update
  params[:article][:producer_title] = Contact.where(id: params[:article][:producer_id]).pluck(:cont_name).first 
end

这行得通,但它是解决这个问题的最佳实践方法吗?

另外,如果我更改要使用的部件,为什么我不能让它工作params[producer_id]id: params[:producer_id]

最好的问候和感谢。

4

1 回答 1

0

像下面这样的东西怎么样:

def edit
  @article = Article.find(params[:id])
  @producers = Contact.where(type: "producer") # or however you distinguish between producers and other contacts
end

然后在您的表单中将其更改为:

f.select :producer_id, options_from_collection_for_select(@producers, "cont_name")
# you might need to do (@producers, "cont_name", "cont_name"), can't quite remember

然后你的更新操作会简单得多:

def update
  @article = Article.find(params[:id])
  if @article.update_attributes(params[:article])
    ...
  else
    ...
  end
end

:id => params[:producer_id]不起作用的原因是这params是一个嵌套的哈希,所以类似于:

params = { :article => { :producer_id => 34, :title => "Cool Article" }, :another_key => { :key => :value } }

所以要访问producer_id你首先必须检索article哈希,否则它只会查看第一组键,其中包括articleanother_key在上面的示例中,但不包括producer_id.

于 2013-04-13T04:08:08.703 回答