array_walk Exécute une fonction sur chacun des éléments d'un tableau &reftitle.description; boolarray_walk arrayarray callbackfuncname mixeduserdata &return.success; Exécute la fonction funcname définie par l'utilisateur sur chaque élément du tableau array. Typiquement, funcname prend deux paramètres. La valeur du paramètre input étant le premier et la clé/index, le second. Si le paramètre optionnel userdata est fourni, il sera passé comme troisième paramètre à la fonction définie par l'utilisateur funcname. Si function requiert plus de paramètres que ceux donnés, une alerte E_WARNING sera générée à chaque fois que la fonction array_walk appellera funcname. Ces alertes peuvent ne pas être affichées en utilisant l'opérateur d'erreur &php; @ lors de l'appel de la fonction array_walk ou en utilisant error_reporting. Si funcname doit travailler avec les véritables valeurs du tableau, spécifiez que le premier paramètre de funcname doit être passé par référence. Alors, les éléments seront directement modifiés dans le tableau. Passer les clés et userdata à funcname a été ajouté en &php; 4.0.0 array_walk n'est pas affecté par le pointeur interne du tableau array. array_walk traversera le tableau en totalité sans se soucier de la position du pointeur. Les utilisateurs ne peuvent pas modifier le tableau lui-même depuis la fonction de callback. Par exemple, Ajout/Effacement d'éléments, réinitialisation d'éléments, etc. Si le tableau sur lequel array_walk est appliqué est changé, le comportement de la fonction est indéfini et non prévisible. Exemple avec <function>array_walk</function> "citron", "a"=>"orange", "b"=>"banane", "c"=>"pomme"); function test_alter(&$item1, $key, $prefix) { $item1 = "$prefix: $item1"; } function test_print ($item2, $key) { echo "$key. $item2
\n"; } echo 'Avant... '."\n"; array_walk ($fruits, 'test_print'); array_walk ($fruits, 'test_alter', 'fruit'); echo '...et après :'."\n"; array_walk ($fruits, 'test_print'); ?> ]]>
&example.outputs;
Voir aussi array_walk_recursive, create_function, list, foreach, each, call_user_func_array, array_map et &seealso.callback;.