回答:
form_for @user, :url => url_for(:controller => 'mycontroller', :action => 'myaction')
または
form_for @user, :url => whatever_path
次は私のために働きます:
form_for @user, :url => {:action => "YourActionName"}
action:
(アクションコロン)api.rubyonrails.org/classes/ActionView/Helpers/...
form_for @user, url: {action: 'myaction'}
がNo route matches {:action=>"myaction", :controller=>"users"}
エラーになります。
resources :users do
collection do
get :myaction
end
end
私はそのようにしました
<%= form_for :user, url: {action: "update", params: {id: @user.id}} do |f| %>
オプションのパラメーターid
がユーザーインスタンスID属性に設定されていることに注意してください。
または、次form_tag
の構文を使用して同じことを行うこともできます。
form_tag({controller: "people", action: "search"}, method: "get", class: "nifty_form")
# => '<form accept-charset="UTF-8" action="/people/search" method="get" class="nifty_form">'
http://guides.rubyonrails.org/form_helpers.html#multiple-hashes-in-form-helper-callsで説明されているとおり
@user
。a form_tag
を使用しても、オブジェクトの属性はフォームフィールドにバインドされません。
部分的なフォームをレンダリングしている間にカスタムコントローラをform_forに渡したい場合は、これを使用できます:
<%= render 'form', :locals => {:controller => 'my_controller', :action => 'my_action'}%>
次に、部分的な形式で、このローカル変数を次のように使用します。
<%= form_for(:post, :url => url_for(:controller => locals[:controller], :action => locals[:action]), html: {class: ""} ) do |f| -%>
url_for
必要だとは思いません。また、コントローラーは同じなので、使用できますform_for @user, :url => :action => 'myaction'