La mejor manera que he encontrado es usar wp_localize_script()
, como sugirió @scribu.
Por lo general, decidí usar Javascript en línea porque necesitaba proporcionar algunas variables PHP a mi script. Esto se puede resolver conwp_localize_script()
. Proporcionaré un ejemplo:
Tiene una matriz $aFoo
con algunas opciones y necesita pasarla a un script.
$aFoo = array( 'option1' => $option1Value, 'option2' => $option2Value );
Usando script en línea:
<script>
var oFoo = {};
oFoo.option1 = <?php echo $aFoo['option1'] ?>;
oFoo.option2 = <?php echo $aFoo['option2'] ?>;
//do some stuff with oFoo
</script>
Utilizando 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' );
Entonces, pathToScript/script.js
sería:
var oFoo = {};
oFoo.option1 = object_name.option1;
oFoo.option2 = object_name.option2;
//do some stuff with oFoo (no PHP needed)
De esta manera, ya no necesita scripts en línea.