为什么Drupal AHAH不会在一个区块内形成工作?

时间:2010-07-17 20:41:43

标签: ajax drupal ahah

我正在尝试将AJAX提交的(AHAH)表单设置为在侧栏上的块中显示。出于测试目的,我正在使用Pro Drupal Development书中名为“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'...)调用表单时,表单提交为normal(没有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));
}

1 个答案:

答案 0 :(得分:1)

尝试添加

$blocks[0]['cache'] = BLOCK_NO_CACHE;

到你的hook_block实现。

使用ahah渲染表单会导致调用drupal_add_js添加ahah javascript,但是当缓存块的输出时,添加到页面的javascript不会。