我正在尝试让 AJAX 提交 (AHAH) 表单显示在侧边栏的块中。出于测试目的,我使用 Pro Drupal 开发书中名为“Poof”的示例模块:http: //books.google.com/books ?id=VmZrdGuBZCMC&lpg=PA269&ots=cnHiYG6kXn&dq=pro%20drupal%20development%20poof&pg= PA269#v=onepage&q=pro%20drupal%20development%20poof&f=false
到目前为止,我添加到示例中的唯一内容是 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 将其引入?这听起来不必要的混乱。
更新:这里有更多代码供参考(同样,它来自 Pro 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));
}