Ajax не работает в Drupal 7 при использовании раздела редактирования - PullRequest
0 голосов
/ 16 сентября 2011

Я также использую drupal-7 и создаю модуль. Форма, в которой есть 2 выпадающих. При выборе модели автомобиля (1-й выпадающий) значение варианта автомобиля (2-й выпадающий) будет меняться. Это отлично работает, когда я создаю новый. Но как только я иду редактировать какое-то значение, оно показывает мне ошибку.

=============================================== ============================

Произошла ошибка AJAX HTTP.

Код результата HTTP: 500

Ниже приведена отладочная информация.

Путь: / vehicle_ades /? Q = system / ajax

StatusText: служба недоступна (с сообщением)

ResponseText: PDOException: SQLSTATE [42S22]: Столбец не найден: 1054 Неизвестный столбец «ajax» в «выражении where»:

ВЫБРАТЬ заголовок, подробности, value_of_offer, exchange_offer, total_savings, car_model_id, car_variant_id FROM {va_offer} где id = ajax; Array ()

=============================================== ============================

Как передать идентификатор модели автомобиля в функцию ajax

1 Ответ

0 голосов
/ 19 сентября 2011

Я работаю над Drupal 7. Ниже приведен код.То, что я сделал, это при выборе модели автомобиля. Вариант автомобиля изменится, и данные сохранятся в таблице.

функция add_offer_form ($ form, $ formstate) {

$ form ['add_offer_new_car_model'] = массив (

'#type' => 'select',
'#required' => TRUE,
'#options' => $car_model,
'#ajax' => array(
    'effect' => 'fade',
    'progress' => array('type' => 'none'),
    'callback' => 'variant_callback',
    'wrapper' => 'replace_variant',
),

);

// поле со списком для выбора нового варианта автомобиля

$ form ['add_offer_new_car_variant'] = массив (

'#type' => 'select',
'#options' => array(),
// The prefix/suffix provide the div that we're replacing, named by #ajax['wrapper'] above.
'#prefix' => '<div id="replace_variant">',
'#suffix' => '</div>',

);

// AJAX-запрос вызывает функцию конструктора форм для каждого изменения.

// Мы можем изменить способ построения формы на основе $ form_state.

if (! Empty ($ formstate ['values'] ['add_offer_new_car_model'])) {

$model_id = $formstate['values']['add_offer_new_car_model'];
$rows = array();
$result = db_query("SELECT id, variant_name from {va_car_variant} where car_model_id in ($model_id,1) order by variant_name");
while ($data = $result->fetchObject()) {
    $id = $data->id;
    $rows[$id] = $data->variant_name;
}
$form['add_offer_new_car_variant']['#options'] = $rows;

}

}

//////////////////////////////////////////////////////// ///////// ФУНКЦИЯ ДЛЯ ОБРАТНОГО ВЫЗОВА AJAX

function variable_callback ($ form, & $ form_state) {

return $ form ['add_offer_new_car_variant'];

}

...