Welcome to the Treehouse Community
Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.
Looking to learn something new?
Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.
Start your free trialDeborah Speken
4,050 PointsHook in the my_plugin_frontend_scripts so CSS and JS display on the front end of the site. Error in add_action?
function my_plugin_frontend_scripts() {
wp_enqueue_style( 'my_plugin_frontend_css', plugins_url( 'my-plugin/css/front-end.css' ) );
wp_enqueue_script( 'my_plugin_frontend_js', plugins_url( 'my-plugin/js/front-end.js' ), array('jquery'), '', true );
}
add_action( 'wp_enqueue_scripts', 'my_plugin_frontend_scripts' );
<?php
function my_plugin_enable_ajax() {
?>
<script>
var ajaxurl = '<?php echo admin_url('admin-ajax.php'); ?>';
</script>
<?php
}
add_action( 'wp_head', 'my_plugin_enable_ajax' );
function my_plugin_frontend_scripts() {
wp_enqueue_style( 'my_plugin_frontend_css', plugins_url( 'my-plugin/css/front-end.css' ) );
wp_enqueue_script( 'my_plugin_frontend_js', plugins_url( 'my-plugin/js/front-end.js' ), array('jquery'), '', true );
}
add_action( 'wp_enqueue_scripts', 'my_plugin_frontend_scripts' );
?>
1 Answer
Sue Dough
35,800 PointsWowowow do not use this. You should never make a function inside of a function. You can call a function within a function but no make one. <<< Nevermind I read the code wrong. The indentation is so hard to read that the functions almost look nested.
You can ditch both functions for 1. The admin ajax url will pass in the javascript if you view the source on the site now.
<?php
/**
* Scripts And Styles
*
*/
add_action( 'wp_enqueue_scripts', 'my_plugin_scripts_and_styles' );
function my_plugin_scripts_and_styles() {
wp_register_style( 'my-plugin-css', plugin_dir_url( __FILE__ ) . '/custom.css', false );
wp_enqueue_style( 'my-plugin-css' );
wp_register_script( 'my-plugin-js', plugin_dir_url( __FILE__ ) . '/custom.js', array( 'jquery' ) );
$settings = array(
'ajax' => admin_url( 'admin-ajax.php' ),
);
wp_localize_script( 'my-plugin-js', 'settings', $settings ); //pass any php settings to javascript
wp_enqueue_script( 'my-plugin-js' );
}
And now anywhere in javascript you can use this to access the ajax url
settings.ajax