2011-12-15 3 views
0

Я все еще работаю над своим собственным модулем Drupal 7, и у меня проблемы. Я пытаюсь загрузить содержимое базы данных в раскрывающийся список (выберите), я прочитал и написал тот же код из примера drupal, но моя база данных все еще не загружается, а только пустая опция. Что я спрашиваю, есть ли что-то не так в моем коде или есть ли более быстрый способ загрузить базу данных в параметр выпадающего, кроме примера drupal ???Как загрузить содержимое базы данных в раскрывающийся список (выберите)

здесь код я работаю над

function prod_entry_load($entry = array()) { 
    $select = db_select('aa_1122','aa'); 
    $select->fields('aa'); 

    foreach ($entry as $field => $value) { 
    $select->condition($field, $value); 
    } 
    return $select->execute()->fetchAll(); 
} 

function prod(){ 
    return drupal_get_form('prod_form'); 
} 
function prod_form($form_state){ 
    $form = array(
     '#prefix' => '<div id="updateform">', 
     '#suffix' => '</div>', 
); 

    $entries = prod_entry_load(); 
    $keyed_entries = array(); 
    if (empty($entries)) { 
    $form['no_values'] = array(
     '#value' => t("No entries exist in the table dbtng_example table."), 
    ); 
    return $form; 
    } 

    foreach ($entries as $entry) { 
    $options[$entry->no] = t("@no: @name ", array('@no' => $entry->no, '@name' => $entry->name)); 
    $keyed_entries[$entry->no] = $entry; 
    } 
    $default_entry = !empty($form_state['values']['no']) ? $keyed_entries[$form_state['values']['no']] : $entries[0]; 

    $form_state['entries'] = $keyed_entries; 

    $form['no'] = array(
    '#type' => 'select', 
    '#title' => t('Choose'), 
    '#default_value' => $default_entry->no, 
    '#ajax' => array(
     'wrapper' => 'updateform', 
     'callback' => 'prod_form_update_callback', 
    ), 
); 
    $form['submit'] = array(
    '#type' => 'submit', 
    '#value' => 'Submit', 
    '#ajax' => array(
     'callback' => 'ajax_alert', 
    ), 
); 
    return $form; 
} 

function prod_form_update_callback($form, $form_state) { 
    $entry = $form_state['entries'][$form_state['values']['no']]; 
    foreach (array('name') as $item) { 
    $form[$item]['#value'] = $entry->$item; 
    } 
    return $form; 
} 

ответ

3

Вы только забыли добавить ключ #options к вашему выбору элементу, код должен выглядеть подобно этому:

$form['no'] = array(
    '#type' => 'select', 
    '#title' => t('Choose'), 
    '#default_value' => $default_entry->no, 
    '#options' => $options, // This is the bit that was missing 
    '#ajax' => array(
    'wrapper' => 'updateform', 
    'callback' => 'prod_form_update_callback', 
), 
); 

Вы могли бы немного сократите код запроса/параметров, используя комбинацию конкатенации строк в MySQL и db fetchAllKeyed():

$query = db_select('aa_1122', 'aa')->fields('aa', array('no')); 
$query->addExpression("CONCAT(no, ': ', name)", 'display'); 
$options = $query->execute()->fetchAllKeyed(); 
+0

Черт, я был так небрежен, как раз тогда, когда мне показалось, что я проверил все. Спасибо Клайву – Altic

Смежные вопросы