繁体   English   中英

WooCommerce订单概述添加带有订购产品的列

[英]WooCommerce Order overview add column with ordered products

我正在尝试改善WooCommerce的“订单概览”屏幕,我想添加一列包含订购产品的栏目。

因此,我可以看到例如以下列:订单号,总订单,已订购产品,地址,注释,操作

我们已经在互联网上找到了一些代码来添加包含产品的列,但是缺少产品SKU。 我目前可以看到的是:

  • 1x产品名称A
  • 3x产品名称C

我想看到的是:

  • 1个ARM-002(产品名称A)
  • 3个ARM-008(产品名称C)

我已经使用此代码添加了列:

add_filter('manage_edit-shop_order_columns', 'add_ordered_products_column', 11);    
function add_ordered_products_column($columns) {
    $columns['order_products'] = "Ordered products";
    return $columns;
}

并在此添加列的内容:

add_action( 'manage_shop_order_posts_custom_column' , 'add_ordered_products_column_content', 11, 2 );
function add_ordered_products_column_content( $column ) {
 global $post, $woocommerce, $the_order;

    switch ( $column ) {

        case 'order_products' :

        $terms = $the_order->get_items();

        if ( is_array( $terms ) ) {
             foreach($terms as $term) {
                echo $term['item_meta']['_qty'][0] .' x '. $term['name'] .'<br />';
            }
        }

        else {
                _e( 'Unable to get products', 'woocommerce' );
        }

        break;
    }
}

我想使用类似$ term ['sku']之类的方法,但这不起作用,get_sku();也不起作用。 有谁知道解决这个问题的办法吗?

首先,如果您要查找产品SKU,请替换以下代码:

echo $term['item_meta']['_qty'][0] .' x '. $term['name'] .'<br />';

有了这个:

$sku = ( $sku = get_post_meta( $term['product_id'], '_sku', true ) ) ? $sku : '';
echo $term['quantity'] . ' ' . $sku . ' x ' . $term['name'] .'<br />';

如果在那之后仍然有问题,建议您检查适用于我的代码

您是否尝试过类似

<?php echo ( $sku = $_product->get_sku() ) ? $sku : __( 'n/a', 'woocommerce' ); ?>

哪里

<?php 
     foreach ( WC()->cart->get_cart() as $cart_item_key => $cart_item ) {
         $_product = apply_filters( 'woocommerce_cart_item_product', $cart_item['data'], $cart_item, $cart_item_key );
         if( necessary conditionals goes here){ ... }        
     }
?>

请注意,自Woocommerce 3.0起,以下代码行:

echo $term['item_meta']['_qty'][0] .' x '. $term['name'] .'<br />';

不再显示订购商品的数量。

如果您使用的是Woocommerce 3.0及更高版本,则必须将其替换为以下代码行:

echo $term['quantity'] .' x '. $term['name'] .'<br />';

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM