xandeadx.ru Блог музицирующего веб-девелопера

Drupal → AJAX submit с поддержкой валидации

Опубликовано в

Пример ajax формы с поддержкой валидации:

/**
 * Form builder.
 */
function modulename_testform($form, &$form_state) {
  $form['testfield'] = array(
    '#type' => 'textfield',
    '#title' => 'Testfield',
    '#required' => TRUE,
  );
 
  $form['submit'] = array(
    '#type' => 'submit',
    '#value' => 'Submit',
    '#ajax' => array(
      'callback' => 'modulename_testform_ajax_submit',
      'wrapper' => 'modulename-testform',
    ),
  );
 
  return $form;
}
 
/**
 * Ajax submit.
 */
function modulename_testform_ajax_submit($form, &$form_state) {
  if (form_get_errors()) {
    return $form;
  }
  else {
    return 'Form submitted';
  }
}

При провале валидации форма перезагрузится и выведутся сообщения об ошибках, иначе вместо формы появится текст "Form submitted".

Написанное актуально для Drupal 7
Похожие записи

Комментарии RSS

не работает...

Извиняюсь, работает, но важно отметить, что нужно правильно указывать 'wrapper':
https://www.drupal.org/node/1264070#comment-5563220

Оставить комментарий

Содержимое этого поля является приватным и не будет отображаться публично. Если у вас есть аккаунт в Gravatar, привязанный к этому e-mail адресу, то он будет использован для отображения аватара.
  • Адреса страниц и электронной почты автоматически преобразуются в ссылки.
  • Доступные HTML теги: <a> <i> <b> <strong> <code> <ul> <ol> <li> <blockquote> <em> <s>
  • Строки и параграфы переносятся автоматически.
  • Подсветка кода осуществляется с помощью тегов: <code>, <css>, <html>, <ini>, <javascript>, <sql>, <php>. Поддерживаемые стили выделения кода: <foo>, [foo].

Подробнее о форматировании