Cara yang lebih baik yang saya temukan adalah menggunakan wp_localize_script()
, seperti yang disarankan @scribu.
Biasanya, saya memutuskan untuk menggunakan Javascript in-line karena saya perlu menyediakan beberapa variabel PHP ke skrip saya. Ini dapat diatasi dengan wp_localize_script()
. Saya akan memberikan contoh:
Anda memiliki larik $aFoo
dengan beberapa opsi dan harus meneruskannya ke skrip.
$aFoo = array( 'option1' => $option1Value, 'option2' => $option2Value );
Menggunakan skrip sebaris:
<script>
var oFoo = {};
oFoo.option1 = <?php echo $aFoo['option1'] ?>;
oFoo.option2 = <?php echo $aFoo['option2'] ?>;
//do some stuff with oFoo
</script>
Menggunakan 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' );
Maka, pathToScript/script.js
akan menjadi:
var oFoo = {};
oFoo.option1 = object_name.option1;
oFoo.option2 = object_name.option2;
//do some stuff with oFoo (no PHP needed)
Dengan cara ini Anda tidak perlu skrip in-line lagi.