Submit
ボタンが欲しいのですが。送信の1つのフィールドを更新します。 submission.state = :submitted
これで、カスタムルートとカスタムアクションを作成して、それに投稿することができました。しかし、それは本当に強引なようです。特に私はreject
ボタンも持っているので、おそらくそれ以上です。それらのそれぞれにカスタムのルートとアクションが必要なのは、私には実にばかげているようです。
私が次のようなことをすることができればもっといいでしょう
button_to "Submit", submission_url(submission), :method => :put, :submission => { :state => :submitted }
これは、送信のupdate
メソッドにポストし、必要なフィールドのみを更新します。
しかし、それはうまくいきません。どうすれば機能させることができますか?それとも、これを行う方法についてより良いアイデアがありますか?
@AugustinRiedingerによって言及された pull request はマージされ、Rails 4.1.0以降で利用可能になりました。次に、params
オプションを追加します。
params: { state: :submitted }
簡潔ではありませんが、Railsを拡張しないと、次のようになります。
= form_for submission, :html => { :class => "button_to" } do |f|
= f.hidden_field :state, :value => :submitted
= f.submit "Submit", :class => "link"
最後にparams:{}を追加すると、hidden_fieldが生成されます
<%= button_to user.name, user, class:"btn btn-default", style:"", method: :patch, remote: true, params: { a_field: false, an_other_field:"a new value" } %>
私はうまくいく似たようなものを持っています:
button_to "Submit", submission_url(submission, :submission => { :state => :submitted }), :method => :put
したがって、これからRailsプルリクエスト: https://github.com/Rails/rails/pull/10471
これがカスタムbutton_toを作成するためにできることです。
application_helper.rb
、次の行を追加します:
module ApplicationHelper
// Unfortunately these 2 methods need to be redefined. I don't know how I could access the original ones.
def token_tag(token=nil)
if token != false && protect_against_forgery?
token ||= form_authenticity_token
tag(:input, type: "hidden", name: request_forgery_protection_token.to_s, value: token)
else
''
end
end
def method_tag(method)
tag('input', type: 'hidden', name: '_method', value: method.to_s)
end
def button_to_with_params(name = nil, options = nil, html_options = nil, &block)
html_options, options = options, name if block_given?
options ||= {}
html_options ||= {}
html_options = html_options.stringify_keys
convert_boolean_attributes!(html_options, %w(disabled))
url = options.is_a?(String) ? options : url_for(options)
remote = html_options.delete('remote')
params = html_options.delete('params') { Hash.new }
method = html_options.delete('method').to_s
method_tag = %w{patch put delete}.include?(method) ? method_tag(method) : ''.html_safe
form_method = method == 'get' ? 'get' : 'post'
form_options = html_options.delete('form') || {}
form_options[:class] ||= html_options.delete('form_class') || 'button_to'
form_options.merge!(method: form_method, action: url)
form_options.merge!("data-remote" => "true") if remote
request_token_tag = form_method == 'post' ? token_tag : ''
html_options = convert_options_to_data_attributes(options, html_options)
html_options['type'] = 'submit'
button = if block_given?
content_tag('button', html_options, &block)
else
html_options['value'] = name || url
tag('input', html_options)
end
inner_tags = method_tag.safe_concat(button).safe_concat(request_token_tag)
params.each do |name, value|
inner_tags.safe_concat tag(:input, type: "hidden", name: name, value: value.to_param)
end
content_tag('form', content_tag('div', inner_tags), form_options)
end
end
そしてそれを使うには:
= button_to_with_params 'Awesome button', awesome_action_path, method: :put, :params => {:my_param => 'my_value'}
楽しい!手すりを楽しんでください!
私が正しく読んだ場合、標準のRailsフォームが標準的な方法で送信されたときに、具体的に何かしたいことを効果的に行いたいと思います。
たとえば、フォームを使用してフォームを送信すると、.
f.submit "Save Changes"
その後
params[:commit] = "Save Changes"
これの良い点は、コントローラーの更新アクションで適切な分岐を実行できることです。
悪いことは、それがもろいということです。ある日あなたや他の誰かがボタンのテキストを変更することを決めた場合、物事は壊れます..これは悪いことです。
K
Rails 3.2.1以降、:formキーを使用して:html_optionsハッシュにパラメータを追加できます。
http://apidock.com/Rails/v3.2.1/ActionView/Helpers/UrlHelper/button_to
これは3.2.1より前のバージョンには存在しなかったため、非表示の属性を持つフォームを宣言するより詳細なソリューションが必要でした。