搜索一下,你就知道

< 返回
当前位置:
打印

商店订单列表添加自定义列

目录

Woocommerce默认的订单列表只支持一些常规列,例如:订单,日期,状态,账单地址,配送地址,合计,操作。那么想展示更多的信息,需要添加自定义列和对应的Meta值。

效果展示

如下图,增加了自定义的Product Name 和第Shipping Address 1

Woocommerce商店订单列表添加自定义列

代码部分

使用方法:将代码加入到主题或者子主题的functions.php


// 添加2列自定义标题 ,放在订单列的后面
add_filter( 'manage_edit-shop_order_columns', 'custom_shop_order_column', 20 );
function custom_shop_order_column($columns)
{
$reordered_columns = array();

// Inserting columns to a specific location
foreach( $columns as $key => $column){
$reordered_columns[$key] = $column;
if( $key == 'order_number' ){
// Inserting after "Status" column
$reordered_columns['custom_column1'] = __( 'Product Name','theme_domain');
$reordered_columns['custom_column2'] = __( 'Shipping Address','theme_domain');
}
}
return $reordered_columns;
}
//为列指定元数据
add_action( 'manage_shop_order_posts_custom_column' , 'custom_orders_list_column_content', 20, 2 );
function custom_orders_list_column_content( $column, $post_id )
{
switch ( $column )
{
case 'custom_column2' :
// Get custom post meta data
$my_var_one = get_post_meta( $post_id, '_shipping_address_1', true );
if(!empty($my_var_one))
echo $my_var_one;

// Testing (to be removed) - Empty value case
else
echo '<small>(<em>no value</em>)</small>';

break;

}
}
//为列指定元数据
add_action( 'manage_shop_order_posts_custom_column' , 'custom_orders_list_column_content2', 20, 2 );
function custom_orders_list_column_content2( $column ){
global $post, $woocommerce, $the_order;

switch ( $column ){
case 'custom_column1' :

foreach ( $the_order->get_items() as $item_id => $item ) {

$product_name = $item->get_name();
// echo $product_name;
echo ' '.$product_name.'<br/>' ;

}


break;
}
}

原始代码出处,查看