Почему формы Drupal AHAH не работают в блоке?
Я пытаюсь заставить AJAX-отправленную (AHAH) форму работать для отображения в блоке на боковой панели. В целях тестирования я использую пример модуля "Poof" из книги Pro Drupal Development: http://books.google.com/books?id=VmZrdGuBZCMC&lpg=PA269&ots=cnHiYG6kXn&dq=pro%20drupal%20development%20poof&pg=PA269
До сих пор я добавил в пример только реализацию hook_block, которая выглядит следующим образом:
function poof_block($op = 'list', $delta = 0, $edit = array()) {
switch ($op) {
case 'list':
$blocks[0]['info'] = t('poof');
return $blocks;
case 'view':
$block['content'] = drupal_get_form('poof_form');
return $block;
}
}
Модуль AJAX работает нормально при отображении на его собственной странице (mydrupalsite.com/poof), но когда я вызываю форму с module_invoke ('poof', 'block'...) в файле шаблона, форма отправляется как обычно (sans AJAX) и обновляет страницу.
Я не могу найти однозначного ответа на вопрос, почему это происходит, хотя нашел что-то косвенно связанное, что говорит о том, что, возможно, AHAH не работает внутри блоков. Если это так, почему? Или еще лучше, что такое обходной путь. Нужно ли размещать его на собственной пустой странице и вносить его с помощью iframe? Это звучит излишне грязно.
ОБНОВЛЕНО: Вот еще код для справки (опять же, это из книги про Drupal)
function poof_form() {
$form['target'] = array(
'#type' => 'markup',
'#prefix' => '<div id="target">',
'#value' => t('Click the button below.'),
'#suffix' => '</div>',
);
$form['submit'] = array(
'#type' => 'button',
'#value' => t('Click Me'),
'#submit'=>false,
'#ahah' => array(
'event' => 'click',
'path' => 'poof/message_js',
'wrapper' => 'target',
'effect' => 'fade',
),
);
return $form;
}
function poof_message_js() {
$output = t('POOF!');
drupal_json(array('status' => TRUE, 'data' => $output));
}
1 ответ
Попробуйте добавить
$blocks[0]['cache'] = BLOCK_NO_CACHE;
к вашей реализации hook_block.
Рендеринг формы с помощью ahah приводит к вызову drupal_add_js для добавления javascript ahah, но в то время как выходные данные блока кэшируются, javascript, который добавляется на страницу, нет.