1

AJAX で送信された (AHAH) フォームをサイドバーのブロックに表示しようとしています。テスト目的で、Pro Drupal Development book の「Poof」というサンプル モジュールを使用しています。 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));
}
4

1 に答える 1

1

追加してみてください

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

あなたのhook_block実装に。

ahahを使用してフォームをレンダリングすると、drupal_add_jsが呼び出されてahah javascriptが追加されますが、ブロックの出力はキャッシュされますが、ページに追加されるjavascriptはキャッシュされません。

于 2011-03-14T21:32:18.547 に答える