Автозаполнение полей в drupal7

Я пытаюсь автозаполнить текстовые поля после выбора элемента из списка выбора. Я имею в виду следующее: сначала я хочу, чтобы пользователь выбрал элемент из списка выбора, а затем появятся еще 3 текстовых поля, и я хочу дать им отличные значения, на основе которых был выбран.

1 ответ

Решение

Вам нужно использовать Drupal "Ajax framework". Пожалуйста, подготовьте свои поля в функции hook_form_alter.

function hook_form_alter(&$form, &$form_state, $form_id) {
  if (isset($form['type']) && $form['type']['#value'] . '_node_settings' == $form_id) {
    $form['select_field'] = array(
      '#ajax' => array(
        'callback' => '_mymodule_ajax_example_simplest_callback',
        'wrapper' => 'replace_textfield_div',
       ),
    );

    // This entire form element will be replaced with an updated value.
    $form['textfield_to_autofill'] = array(
      '#prefix' => '<div id="replace_textfield_div">',
      '#suffix' => '</div>',
    );
  }
}
function _mymodule_ajax_example_simplest_callback(&$form, $form_state) {
  // The form has already been submitted and updated. We can return the replaced
  // item as it is.
  $commands = array();
  if($form_state['values']['select_field'][LANGUAGE_NONE][0]['value'] == "some_value"){
    $form['textfield_to_autofill'][LANGUAGE_NONE][0]['value']['#value'] = "some_value";
    $commands[] = ajax_command_replace("#replace_textfield_div", render($form['textfield_to_autofill']));
  }
  $page = array('#type' => 'ajax', '#commands' => $commands);
  ajax_deliver($page);
}

Здесь помогает ссылка для ajax framework.

Другие вопросы по тегам