Я пытаюсь использовать AJAX на страницах интерфейса пользователя из плагина в WordPress Multisite, но admin-ajax.php генерирует неверный запрос 400 и всегда терпит неудачу.
- Разработка плагина WordPress - AJAX на административных страницах работает хорошо
- WordPress Мультисайт
- Тестировать на Site_1
Это часть моего кода и вывода, я просто сокращаю его. Есть класс для создания экземпляров действий AJAX и еще один после него для включения файла JS с помощью действия wp_enqueue_scripts ..
В любом случае файл JS включен правильно, а функция console.log отображает весь объект данных JS, как вы видите в приведенном ниже коде, НО это всегда не удается, и аргумент msg выводит неверный запрос в statusText .. Что я упустил ??
/* == AJAX Class == */
add_action( 'wp_ajax_wpmu_frontendpage', array( &$this, '_class_function' ) );
add_action( 'wp_ajax_nopriv_wpmu_frontendpage', array( &$this, '_class_function' ) );
/* 1. The JS file included correctly */
wp_register_script( 'wpmu/scripts/frontend/core', 'JS_FILE.js',
array( 'jquery' ), '1.0', true );
/* 2. Localize */
wp_localize_script( 'wpmu/scripts/frontend/core', 'wpmu_ajax', array (
'ajax_url' => esc_url( admin_url('admin-ajax.php') )
)
);
/* 3. Enqueue */
wp_enqueue_script( 'wpmu/scripts/frontend/core' );
== JS FILE ==
(function ($) {
'use strict';
$.wpmu = $.wpmu || {};
$.wpmu.ajax_vars = {
ajax_url: wpmu_ajax.ajax_url,
};
$(document).ready(function () {
/* 1. DEBUG */
console.log($.wpmu.ajax_vars);
/* 2. DEBUG - OUTPUT */
-- ajax_vars:
-- ajax_url: "http://localwp.com:90/wpmu/SITE_1/wp-admin/admin-ajax.php"
/* ========= Main Code ======== */
$(document.body).on('click', '#my-wrapper .submit', function (e) {
e.preventDefault();
var server_data = {
action: 'wpmu_frontendpage',
};
$.ajax({
method: 'POST',
async: true,
url: $.wpmu.ajax_vars.ajax_url,
data: server_data,
}).done(function (response) {
alert('success');
}).fail(function (msg) {
console.log( msg );
});
return false;
});
});
})(jQuery);