Php 添加操作按钮和;控制员;到订单列表(管理)-WooCommerce

Php 添加操作按钮和;控制员;到订单列表(管理)-WooCommerce,php,wordpress,woocommerce,Php,Wordpress,Woocommerce,几个小时以来,我一直在尝试添加一个带有“控制器”部分的操作按钮来接收请求 我试图添加一个真正的“动作按钮”,但它不起作用。我在许多StackOverflow帖子中尝试了很多方法,但都不起作用 因此,我添加了一个指向自定义列的链接: add_filter( 'manage_edit-shop_order_columns', 'custom_set_order_columns' ); function custom_set_order_columns($columns){ $new_colu

几个小时以来,我一直在尝试添加一个带有“控制器”部分的操作按钮来接收请求

我试图添加一个真正的“动作按钮”,但它不起作用。我在许多StackOverflow帖子中尝试了很多方法,但都不起作用

因此,我添加了一个指向自定义列的链接:

add_filter( 'manage_edit-shop_order_columns', 'custom_set_order_columns' );
function custom_set_order_columns($columns){
    $new_columns = (is_array($columns)) ? $columns : array();
    unset( $new_columns['order_actions'] );
        unset( $new_columns['order_total'] );

    $new_columns['test_button'] = 'Test';
    $new_columns['order_actions'] = $columns['order_actions'];

    return $new_columns;
}
设置列值:

add_action( 'manage_shop_order_posts_custom_column', 'custom_set_order_column_values', 2 );
function custom_set_order_column_values($column){
    global $post;

    $order = wc_get_order( $post->ID );
    $email = $order->get_billing_email();
    $admin_ajax_url = admin_url("admin-ajax.php");

    $link_btn = "<a href='#' class='button button-primary' onclick='start(\"$email\",\"$admin_ajax_url\")'>Start</a>";
    
  if ( $column == 'test_button' ) {
    echo $link_btn;
  }
}
由于我不经常使用WordPress/WooCommerce,这对我来说似乎很难。 我不需要AJAX帖子。我想知道一种在订单列表中添加真实按钮的方法,单击按钮后,请求会转到“test_button_post()”之类的方法,在该方法中,我会自动呈现通知消息和页面重定向

类似于:
按钮单击->测试按钮发布方法(充当控制器)并重定向以显示通知消息

在test_button_post方法中,我需要获取参数并向外部API发出请求,然后显示结果

我不知道这样做是否正确

WordPress版本:5.5
WooCommerce版本:4.4.1

function start(email, adminAjaxUrl) {
  jQuery.ajax({
      url : adminAjaxUrl,
      type : 'POST',
      data : {
          action : 'test_button_post',
          param1: email
      },
      success : function( response ) {
        var success = JSON.parse(response)['success'] == "true";
        if (success) {
          jQuery('#wpbody-content .wrap ul').before('<div class="notice notice-success"><p>' + response['message'] + '</p></div>');
        } else {
          jQuery('#wpbody-content .wrap ul').before('<div class="notice notice-info"><p>' + response['message'] + '</p></div>');
        }
      }
  });
}
add_action( 'wp_ajax_test_button_post', 'test_button_post' );
function test_button_post() {
  if (!($_SERVER['REQUEST_METHOD'] === 'POST')) {
    die();
  }

  $response['success'] = "true";
  $response['email'] = $_REQUEST['param1'];
  $response['message'] = "some message";
  echo json_encode($response);
  die();
}