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)
我遇到过这个问题几次,这不是一个缓存问题.问题是你最初会把<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.
| 归档时间: |
|
| 查看次数: |
2744 次 |
| 最近记录: |