我有一個自定義postmeta
字段,它以序列化方式存儲post/product_id。示例_related_ids
=>a:4:{i:0;i:2462;i:1;i:2466;i:2;i:2469;i:3;i:2472;}
WooCommerce自定義產品列可排序支持不工作
我在WooCommerce產品清單屏幕(支持)中顯示_related_ids
的product_id計數,該工作正常。現在我想讓這個列可排序。所以我寫了一個函數related_product_col_sort
,這個函數連接到manage_edit-product_sortable_columns
。列短路不起作用。 (不工作意味着它沒有正確訂購product_id計數)。
這裏是我完整的代碼
//_related_ids => a:4:{i:0;i:2462;i:1;i:2466;i:2;i:2469;i:3;i:2472;}
//manage_product_posts_custom_column
add_filter('manage_edit-product_columns', 'related_product_col');
function related_product_col($columns) {
$new_columns = (is_array($columns)) ? $columns : array();
$new_columns['RELATED'] = 'Related Product';
return $new_columns;
}
add_action('manage_product_posts_custom_column', 'related_product_col_data', 2);
function related_product_col_data($column) {
global $post;
$related_product_ids = get_post_meta($post->ID, '_related_ids', true);
if ($column == 'RELATED') {
if (isset($related_product_ids) && !empty($related_product_ids)) {
echo count($related_product_ids);
} else {
echo "--";
}
}
}
add_filter("manage_edit-product_sortable_columns", 'related_product_col_sort');
function related_product_col_sort($columns) {
$custom = array(
'RELATED' => '_related_ids'
);
return wp_parse_args($custom, $columns);
}
誰能幫我用related_product_col_sort
功能正確的邏輯/代碼。
謝謝。
我想我明白了我錯在哪裏,會嘗試一下並且會更新你。而且我正在使用相關產品插件以序列化方式存儲值,我想我必須編輯該插件以使排序邏輯更容易。謝謝。 –