Antworten:
form_for @user, :url => url_for(:controller => 'mycontroller', :action => 'myaction')
oder
form_for @user, :url => whatever_path
Folgendes funktioniert für mich:
form_for @user, :url => {:action => "YourActionName"}
action:
( Aktionspunkt ) api.rubyonrails.org/classes/ActionView/Helpers/…
form_for @user, url: {action: 'myaction'}
aber es gibt mir No route matches {:action=>"myaction", :controller=>"users"}
Fehler.
resources :users do
collection do
get :myaction
end
end
Ich habe es so gemacht
<%= form_for :user, url: {action: "update", params: {id: @user.id}} do |f| %>
Beachten Sie den optionalen Parametersatz id
für das Benutzerinstanz-ID-Attribut.
Alternativ kann dasselbe form_tag
mit der folgenden Syntax erreicht werden:
form_tag({controller: "people", action: "search"}, method: "get", class: "nifty_form")
# => '<form accept-charset="UTF-8" action="/people/search" method="get" class="nifty_form">'
Wie unter http://guides.rubyonrails.org/form_helpers.html#multiple-hashes-in-form-helper-calls beschrieben
@user
. Durch die Verwendung von a form_tag
werden die Attribute des Objekts nicht an die Formularfelder gebunden.
Wenn Sie beim Rendern eines Teilformulars einen benutzerdefinierten Controller an form_for übergeben möchten, können Sie Folgendes verwenden:
<%= render 'form', :locals => {:controller => 'my_controller', :action => 'my_action'}%>
und dann in der Form teilweise diese lokale Variable wie folgt verwenden:
<%= form_for(:post, :url => url_for(:controller => locals[:controller], :action => locals[:action]), html: {class: ""} ) do |f| -%>
url_for
es notwendig ist. Auch da Controller der gleiche ist, könnten Sie verwendenform_for @user, :url => :action => 'myaction'