11

我正在开发一个通过表单发送数据的 Rails 应用程序。我想在表单发送,但在处理之前修改表单的一些“参数” 。

我现在拥有的

{"commit"=>"Create",
  "authenticity_token"=>"0000000000000000000000000"
  "page"=>{
    "body"=>"TEST",
    "link_attributes"=>[
      {"action"=>"Foo"},
      {"action"=>"Bar"},
      {"action"=>"Test"},
      {"action"=>"Blah"}
    ]
  }
}

我想要的是

{"commit"=>"Create",
  "authenticity_token"=>"0000000000000000000000000"
  "page"=>{
    "body"=>"TEST",
    "link_attributes"=>[
      {"action"=>"Foo",
       "source_id"=>1},
      {"action"=>"Bar",
       "source_id"=>1},
      {"action"=>"Test",
       "source_id"=>1},
      {"action"=>"Blah",
       "source_id"=>1},
    ]
  }
}

这可行吗?基本上,我试图一次提交两种类型的数据(“页面”和“链接”),并将“链接”的“source_id”分配给“页面”的“id”。

4

3 回答 3

18

在将其提交到数据库之前,您可以在控制器中编写代码,该代码将获取参数并在保存之前附加不同的信息。例如:

FooController < ApplicationController

  def update
    params[:page] ||= {}
    params[:page][:link_attributes] ||= []
    params[:page][:link_attriubtes].each { |h| h[:source_id] ||= '1' }
    Page.create(params[:page])
  end

end
于 2009-01-08T20:28:18.820 回答
10

在使用强参数之前编辑参数

好的,所以(恢复这个老问题)我遇到了很多麻烦,我想在它到达模型之前修改一个参数(并保持强大的参数)。我终于想通了,这是基础知识:

def update
  sanitize_my_stuff
  @my_thing.update(my_things_params)
end

private

def sanitize_my_stuff
  params[:my_thing][:my_nested_attributes][:foo] = "hello"
end

def my_things_params
  params.permit(etc etc)
end
于 2017-09-25T08:13:23.807 回答
2

您还应该查看回调,特别是 before_validate(如果您使用验证)、before_save 或 before_create。

在不知道如何保存数据的情况下,很难为您提供如何使用它们的具体示例,但它可能看起来与 Gaius 给出的示例非常相似。

于 2009-01-09T13:45:20.670 回答