我有一个类似
的ajax邮件表单 - form_remote_tag :url=>mails_path,:condition=>"validate_mail()", :html => {:id=>"mailform",:method => :post, :class => 'ajax',:style=>"padding:15px;" } do |form|
.gimmespace
Naam
%br
= text_field_tag :name,params[:name],:class=>"title required"
.gimmespace
Telefoonnummber
%br
= text_field_tag :phone,params[:phone],:size=>25,:class=>"title"
.gimmespace
Mailadres
%br
= text_field_tag :email,params[:email],:size=>30,:class=>"title required"
.gimmespace
Onderwerp
%br
= text_field_tag :subject,params[:subject],:class=>"title required"
.gimmespace
Boodschap
%br
= text_area_tag :message,params[:message],:rows=>10,:cols=>45,:class=>"title required"
.gimmespace
= submit_tag "Verstuur",:id=>"mailsubmit",:class=>"sendBtn"
%button{:onclick=>"$.fn.colorbox.close();"} Annuleer
以上代码在HAML中。它将ajax表单提交给控制器。我必须在提交之前验证字段。所以,我尝试了几个东西。我读了这篇文章http://hillemania.wordpress.com/2006/09/18/rails-ajax-pre-submit-form-validation/并在回调测试javascript函数之前进行了验证。这是javascript验证功能。
function validate_mail() {
alert("Your Name, Email, Subject and Body Content are Required !");
return false;
}
根据上面的函数,它以任何方式返回false,并且表单不应该被提交但是,它提交得非常好。还有其他方法,请帮忙。
答案 0 :(得分:0)
我认为您要使用:condition
选项而不是:before
选项。像这样:
- form_remote_tag :url=> mails_path, :condition => "validate_mail()", ...
然后,如果您的condition
函数返回false,则不应提交表单。
当然,您需要修改validate_mail()
函数,实际测试每个表单字段不为空:
if ($('name').value == '' || $('phone').value == '' || ... ) {
alert('Something was blank...');
return false;
} else {
return true;
}
我的原型语法生锈 - 这应该会让你走上正确的轨道。