Как проверить отправку формы Ajax (remote_form_tag)? - PullRequest
0 голосов
/ 12 августа 2010

У меня есть форма 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 в любом случае, и форма не должна быть отправлена, но она хорошо отправляется Ajaxical Есть ли другой способ, пожалуйста, помогите.

1 Ответ

0 голосов
/ 12 августа 2010

Я думаю, что вы хотите использовать опцию :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;
}

Мой синтаксис прототипа ржавый - это должно привести вас на правильный путь.

...