A melhor maneira que eu encontrei é usando wp_localize_script()
, como sugeriu @scribu.
Geralmente, eu decidia usar o Javascript em linha porque precisava fornecer algumas variáveis PHP ao meu script. Isso pode ser resolvido com wp_localize_script()
. Vou dar um exemplo:
Você tem uma matriz $aFoo
com algumas opções e precisa transmiti-la para um script.
$aFoo = array( 'option1' => $option1Value, 'option2' => $option2Value );
Usando script em linha:
<script>
var oFoo = {};
oFoo.option1 = <?php echo $aFoo['option1'] ?>;
oFoo.option2 = <?php echo $aFoo['option2'] ?>;
//do some stuff with oFoo
</script>
Usando 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' );
Então, pathToScript/script.js
seria:
var oFoo = {};
oFoo.option1 = object_name.option1;
oFoo.option2 = object_name.option2;
//do some stuff with oFoo (no PHP needed)
Dessa forma, você não precisa mais de scripts em linha.