Drupal Ajax缓存

sch*_*eck 2 php drupal drupal-7 drupal-modules

我正在更新我从D6写到D7的模块,因此必须通过新的#ajax表格交换旧的AHAH.

我正在执行一个ajax请求,它创建一个结果并用它替换一个表单元素.这基本上可以正常工作,但在第一次请求之后,结果会被缓存,并且不会考虑表单中的更改.我认为这可能是一个浏览器问题,但可能是Drupal发送了一个过期标头,导致浏览器采用缓存版本?还有其他想法吗?

hook_cache()中的片段:

  $form['fieldset']['mybutton'] = array(
    '#type' => 'button',   
    '#value' => t('Send request'),
    '#ajax' => array(
          'callback' => 'mycallback',
          'wrapper' => 'mywrapper',
          'method' => 'replace',
          'effect' => 'fade',  
    )
Run Code Online (Sandbox Code Playgroud)

一个回调片段:

function mycallback($form, $form_state) {

        [..]

        $form['fieldset']['mywrapper']['#markup'] = 'test';
        return $form['fieldset']['mywrapper']['#markup'];
    }
Run Code Online (Sandbox Code Playgroud)

Cli*_*ive 9

我遇到过这个问题几次,这不是一个缓存问题.问题是你最初会把<div>你的mywrapper元素包裹起来,但是在你的ajax回调中你用字符串替换它...因此<div>包装器被替换,下次按下按钮时脚本无法找到<div>它需要更换,因为它不再存在!

此外,为您的参数mycallback需要通过引用传递在这样更改签名给这个函数:function mycallback(&$form, &$form_state) {.

尝试使您的代码看起来更像这样:

function mymodule_my_form($form, &$form_state) {
  $form['fieldset'] = array(
    '#type' => 'fieldset'
  );

  $form['fieldset']['my_element'] = array(
    '#markup' => 'Some initial markup',
    '#prefix' => '<div id="mywrapper">',
    '#suffix' => '</div>'
  );

  $form['fieldset']['mybutton'] = array(
    '#type' => 'button',   
    '#value' => t('Send request'),
    '#ajax' => array(
      'callback' => 'mymodule_mycallback',
      'wrapper' => 'mywrapper',
      'method' => 'replace',
      'effect' => 'fade',  
    )
  );

  return $form;
}


function mymodule_mycallback(&$form, &$form_state) {
  $form['fieldset']['my_element']['#markup'] = 'New Markup';

  // Always, always, always return an element here, not a string.
  // This makes sure the form state stays consistent.
  return $form['fieldset']['my_element'];
}
Run Code Online (Sandbox Code Playgroud)

如果有疑问,请查看示例模块,特别是模块中ajax_example_submit_driven_ajax()示例ajax_example.