Перенаправление после отправки формы с помощью ajax в WordPress - PullRequest
0 голосов
/ 25 апреля 2019

У меня есть форма, которая использует Ajax для отправки на WordPress. Форма работает нормально, информация из нее поступает в базу данных и сохраняется правильно.

Проблема в том, что я не могу заставить его перенаправить на другую страницу. Форма действительно простая

<form method="post" id="main">
                <?php wp_nonce_field( 'my_nonce' ); ?>

     <div class="columns is-multiline">
         <div class="column is-4">
             <input type="text" name="firstname" />
         </div>
         <div class="column is-4">
             <input type="text" name="middlename" />
         </div>
         <div class="column is-4">
             <input type="text" name="lastname" />
         </div>
     </div>
     <div id="success_message"></div>
         <div class="columns">        
             <div class="column is-3">
                 <input type="submit" name="submit-button" id="submit-button" value="Submit" />
             </div>
         </div>
     </div>
</form>

Тогда у меня есть это в functions.php

add_action('wp_enqueue_scripts', 'my_ajax_scripts'); 
function my_ajax_scripts(){
    wp_localize_script( 'myscript', 'myajax', array( 'ajaxurl' =>   admin_url( '/admin-ajax.php' ) ) );
}

add_action('wp_enqueue_scripts', 'ajax_scripts'); 
function ajax_scripts(){
    wp_enqueue_script( 'form', get_template_directory_uri().'/assets/js/form.js', array('jquery'), '1.0', true );

}

function form(){

        global $wpdb;

        if (!check_ajax_referer( 'my_nonce' )){
            wp_die();
        }

        $table = UPC_jobs;

        $formdata = $_POST['formdata'];

        parse_str($formdata, $formdata_array);

        $data = array(
            'firstname' => $_POST['firstname'],
            'middlename' => $_POST['middlename'],
            'lastname' => $_POST['lastname'],
        );

        $format = array(
            '%s', '%s', '%s',' %s'
        );        
        $success=$wpdb->insert( $table, $data, $format );
        if($success) {
            wp_redirect( '/my-target' );
            wp_die();
        }
}

А если понадобится JS часть

$('#main').submit(function(e) {
    e.preventDefault();

    var form = $(this);
    var formdata = (window.FormData) ? new FormData(form[0]) : null;
    var data = (formdata !== null) ? formdata : form.serialize();

    formdata.append("action", "form");

    $.ajax({
        type: 'POST',
        url: myajax.ajaxurl,
        contentType: false,
        processData: false,
        dataType: 'JSON',
        status: 200,
        data: formdata,
        success: function( data ){     
            window.location.replace("https://example"); // this doesn't work as well 
        },          
    });         
});

Когда я нажимаю Submit, ничего не происходит, абсолютно ничего. Вся информация хранится в базе данных, как и должно быть, но страница ничего не реагирует / не показывает.

Также рабочим решением было бы просто показать сообщение об успешной отправке формы (без предупреждения)

1 Ответ

1 голос
/ 25 апреля 2019

Вы пытались вместо успешного обратного вызова использовать всегда ? В вашем случае вы можете попробовать это

$.ajax({
        type: 'POST',
        url: myajax.ajaxurl,
        contentType: false,
        processData: false,
        dataType: 'JSON',
        status: 200,
        data: formdata            
    }).always(function() {     
       window.location.replace("https://example"); // this doesn't work as well 
    });         
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...