我有一个发送电子邮件的form_tag,我想使用AJAX,这样只有表单可以更新,其余的看起来都一样。
contact.html.erb
<%= form_tag(site_contact_path, remote: true, class: 'response form-horizontal', authenticity_token: true) do %>
<h2 class="contact-title">Parašykite mums</h2>
<div class="form-group">
<label class="control-label col-sm-4" for="name">Vardas</label>
<div class="col-sm-8">
<%= text_field_tag 'name', nil, placeholder: 'Įveskite vardą', class: 'form-control', autocomplete: 'on' %>
</div>
</div>
<div class="form-group">
<label class="control-label col-sm-4" for="email">El. paštas</label>
<div class="col-sm-8">
<%= text_field_tag 'email', nil, placeholder: 'Įveskite el.paštą', class: 'form-control', autocomplete: 'on' %>
</div>
</div>
<div class="form-group">
<label class="control-label col-sm-4" for="comment">Komentarai</label>
<div class="col-sm-8">
<%= text_area_tag 'comment', nil, placeholder: 'Jūsų komentaras', class: 'form-control', autocomplete: 'on', rows: '6' %>
</div>
</div>
<%= hidden_field_tag :authenticity_token, form_authenticity_token %>
<div class="button-holder">
<%= submit_tag 'Siųsti', class: 'submit' %>
</div>
<div class="hidden">
<p>Ačiū! (Mes pasistenksime atsakyti Jums, kuo greičiau)</p>
</div>
<% end %>
的routes.rb
post '/contact' => 'site#contact_send_email'
site_controller.rb
def contact_send_email
@name = params[:name]
@email = params[:email]
@comment = params[:comment]
ContactMailer.send_message(@name, @email, @comment).deliver
respond_to do |format|
format.js
end
end
contact_send_email.js.erb
$('.form-group').hide();
$('.button-holder').hide();
$('.hidden').show();
日志
ActionController::UnknownFormat (ActionController::UnknownFormat): app/controllers/site_controller.rb:24:in `contact_send_email'
当我按下提交按钮时,电子邮件会被发送但似乎contact_send_email操作由于某种原因找不到contact_send_email.js.erb或者不理解format.js 我已经尝试在StackOverflow上搜索类似的问题,但解决方案似乎没有产生任何影响。
答案 0 :(得分:3)
在您的form_tag中,将第一个参数site_contact_path
更改为contact_path
。
同时将路线上的线路更改为:
post '/contact' => 'site#contact_send_email', defaults: { format: 'js' }
这可以解决您的问题。