La meilleure façon que j'ai trouvée est d'utiliser wp_localize_script()
, comme suggéré par @scribu.
D'habitude, j'ai décidé d'utiliser Javascript en ligne car je devais fournir des variables PHP à mon script. Cela peut être résolu avec wp_localize_script()
. Je vais donner un exemple:
Vous avez un tableau $aFoo
avec quelques options et vous devez le transmettre à un script.
$aFoo = array( 'option1' => $option1Value, 'option2' => $option2Value );
Utiliser un script en ligne:
<script>
var oFoo = {};
oFoo.option1 = <?php echo $aFoo['option1'] ?>;
oFoo.option2 = <?php echo $aFoo['option2'] ?>;
//do some stuff with oFoo
</script>
Utilisant wp_localize_script()
:
wp_register_script( 'script_name', 'pathToScript/script.js', array( 'jquery' )); //if jQuery is not needed just remove the last argument.
wp_localize_script( 'script_name', 'object_name', $aFoo ); //pass 'object_name' to script.js
wp_enqueue_script( 'script_name' );
Alors, pathToScript/script.js
serait:
var oFoo = {};
oFoo.option1 = object_name.option1;
oFoo.option2 = object_name.option2;
//do some stuff with oFoo (no PHP needed)
De cette façon, vous n'avez plus jamais besoin de scripts en ligne.