Odpowiedzi:
form_for @user, :url => url_for(:controller => 'mycontroller', :action => 'myaction')
lub
form_for @user, :url => whatever_path
U mnie działa:
form_for @user, :url => {:action => "YourActionName"}
action:
( dwukropek akcji ) api.rubyonrails.org/classes/ActionView/Helpers/ ...
form_for @user, url: {action: 'myaction'}
ale daje mi to No route matches {:action=>"myaction", :controller=>"users"}
błąd.
resources :users do
collection do
get :myaction
end
end
Zrobiłem to w ten sposób
<%= form_for :user, url: {action: "update", params: {id: @user.id}} do |f| %>
Zwróć uwagę na opcjonalny parametr id
ustawiony na atrybut id instancji użytkownika.
Alternatywnie można osiągnąć to samo, używając form_tag
składni:
form_tag({controller: "people", action: "search"}, method: "get", class: "nifty_form")
# => '<form accept-charset="UTF-8" action="/people/search" method="get" class="nifty_form">'
Jak opisano w http://guides.rubyonrails.org/form_helpers.html#multiple-hashes-in-form-helper-calls
@user
. Użycie a form_tag
nie spowoduje powiązania atrybutów obiektu z polami formularza.
Jeśli chcesz przekazać niestandardowy kontroler do form_for podczas renderowania częściowego formularza, możesz użyć tego:
<%= render 'form', :locals => {:controller => 'my_controller', :action => 'my_action'}%>
a następnie w formie częściowej użyj tej zmiennej lokalnej w ten sposób:
<%= form_for(:post, :url => url_for(:controller => locals[:controller], :action => locals[:action]), html: {class: ""} ) do |f| -%>
url_for
jest to konieczne. Ponieważ kontroler jest taki sam, możesz użyćform_for @user, :url => :action => 'myaction'