function ajax_example_simplest($form, &$form_state) {
//This is my ajax trigger element
$form['element_trigger'] = array(
'#type' => 'select',
'#options' => array(
'one' => 'one',
'two' => 'two',
'three' => 'three',
),
'#ajax' => array(
'callback' => 'ajax_example_simplest_callback',
/** Q: Can I somehow declare more than one wrapper? **/
//Say for instance, something like:
'wrapper' => array('replace_div_1', 'replace_div_2'),
),
);
//replace_div_1
$form['element_to_be_replaced_1'] = array(
'#type' => 'textfield',
'#title' => t("My conditional field one"),
'#prefix' => '<div id="replace_div_1">',
'#suffix' => '</div>',
);
//... more form elements here
//replace_div_2
$form['element_to_be_replaced_2'] = array(
'#type' => 'textfield',
'#title' => t("My conditional field two"),
'#prefix' => '<div id="replace_div_2">',
'#suffix' => '</div>',
);
return $form;
}
function ajax_example_simplest_callback($form, $form_state) {
//... do my stuff here
//normally I would return only the form bit for replacing a single wrapper
//declared in the trigger element, like this:
return $form['element_to_be_replaced_blahblah'];
}
Est-il possible de retourner plus d'un bit de forme dans la fonction de rappel en indiquant au framework AJAX que $form['element_to_be_replaced_1']
devrait remplacer <div id="replace_div_1">
et $form['element_to_be_replaced_2']
devrait remplacer <div id="replace_div_2">
?
Au lieu de renvoyer le code HTML de l'élément unique à mettre à jour, votre rappel ajax peut renvoyer un tableau de commandes ajax . Il peut donc retourner deux ajax_command_replace pour remplacer chaque élément.
function ajax_example_simplest_callback(&$form, $form_state) {
return array(
'#type' => 'ajax',
'#commands' => array(
ajax_command_replace("#replace_div_1", render($form['element_to_be_replaced_1'])),
ajax_command_replace("#replace_div_2", render($form['element_to_be_replaced_2']))
)
);
}
Syntaxe alternative Drupal 8
use Drupal\Core\Ajax\AjaxResponse;
use Drupal\Core\Ajax\ReplaceCommand;
class name extends FormBase{
function ajax_example_simplest(array $form, FormStateInterface &$form_state) {
$response = new AjaxResponse();
$response->addCommand(new ReplaceCommand("#replace_div_1", ($form['element_to_be_replaced_1'])));
$response->addCommand(new ReplaceCommand("#replace_div_2", ($form['element_to_be_replaced_2'])));
return $response;
}
}
Une différence est que la commande de rendu est supprimée, car AjaxResponse implémente Drupal\Core \Rendre\ AttachmentsInterface
rendre($ form ['element_to_be_replaced_1'])
L'ajout du rendu fonctionne toujours, mais j'ai eu des problèmes lors de la mise à jour d'une table TableSelect de cette façon.
La réponse de Pierre Buyle n'a pas fonctionné pour moi. Cependant, quelque chose comme ce qui suit a fonctionné.
function ajax_example_simplest_callback(&$form, $form_state) {
$commands = array();
$commands[] = ajax_command_replace("#replace_div_1", render($form['element_to_be_replaced_1']));
$commands[] = ajax_command_replace("#replace_div_2", render($form['element_to_be_replaced_2']));
$page = array('#type' => 'ajax', '#commands' => $commands);
ajax_deliver($page);
}
Notez l'appel à ajax_deliver () , plutôt que de renvoyer le tableau de commandes AJAX.