AJAX не вызывает действие в WordPress при разработке с использованием Roots.io
Вот мой код в setup.php
:
add_action('wp_enqueue_scripts', function () {
wp_enqueue_style('sage/main.css', asset_path('styles/main.css'), false, null);
wp_enqueue_script('sage/main.js', asset_path('scripts/main.js'), ['jquery'], null, true);
// AJAX Setup
if ( is_search() ) {
wp_enqueue_script('ajax', asset_path('scripts/ajax.js'), ['jquery'], null, true);
}
wp_localize_script( 'ajax', 'ajaxObject', array(
'ajax_url' => admin_url( 'admin-ajax.php' )
) );
, 100);
В моем ajax.js
:
jQuery(document).ready( function($) {
$(".toBeClicked").on('click', function() {
jQuery.ajax({
type: 'POST',
url: ajaxObject.ajax_url,
data: { action: "get_newData", newData: 'New data' },
success: function() {
console.log("success");
},
});
});
})
Наконец, в моем functions.php
:
// Define a variable that will store data from AJAX
$GLOBALS['newData'] = null;
function get_newData() {
$GLOBALS['newData'] = $_POST['newData'];
echo $GLOBALS['newData'];
wp_die();
}
add_action( 'wp_ajax_get_newData', 'get_newData' );
add_action( 'wp_ajax_nopriv_get_newData', 'get_newData' );
Теперь, когда я щелкнул элемент с классом "toBeClicked", консоль успешно распечатывается, но моя функция get_newData
не исполняется.
Я что-то упускаю при настройке? Кроме того, мои wp_ajax_
add_action
функции в нужном файле?