保存用户meta以在保存时发布meta



我想在保存后向帖子(在我的案例中是WooCommerce产品(添加一些用户元。我想这是最好的方法吗?

我找到了一个解决方案,它可以做这样的事情:https://wordpress.stackexchange.com/a/273271/96806

但它似乎只做过一次?

这是代码:

function update_post_meta_with_user_meta() {
//setup arguments to only get users with author role
$user_args = array( 
'role' => 'author', 
);
$authors   =  get_users( $user_args );
//the below foreach could be replaced by adding something like:
// fields => array( 'ID' ) to $user_args
//instead I am just going through returned array of WP_User objects 
//  and putting IDs into array
foreach ( $authors as $a ) {
$author_ids[] = $a->ID;
}
//setup post query arguments to only give us posts with authors in author_id array
//which means only posts that have an author with the WP role of author
// should exclude Editors, Admins, etc. that maybe have authored posts
$post_args = array(
'author__in' => $author_ids,
);
//a new WP_Query with these args   
$post_query   = new WP_Query( $post_args ) ) );
//make sure we have posts returned
if ( $post_query->have_posts() ) {
//loop
while ( $post_query->have_posts() ) {
$post_query->the_post();
//set $post_id variable to current post
$post_id = get_the_id();
//get author meta for author of current post
$author_genere = get_the_author_meta('genere');
//update the meta of the current post (by ID) 
//  with the value of its author's user meta key
update_post_meta( $post_id, 'genere', $author_genere );
}
//reset the postdata
wp_reset_postdata();
}
}
//hook the above to init
add_action( 'init', 'update_post_meta_with_user_meta' );

在保存帖子/产品时,有什么方法可以做到这一点吗?

虽然您的答案可能是"变通方法",但它包含了一些不必要的步骤,并且有一个更适合的钩子。

  • woocommerce_admin_process_product_object-在后端保存产品时保存产品元数据:
function action_woocommerce_admin_process_product_object( $product ) {
$vendor_id   = $product->post_author;
$vendor_info = get_userdata( $vendor_id );
$vendor_name = get_user_meta( $vendor_id, 'pv_shop_name', true );

// For testing purposes, delete afterwards
$vendor_name = 'the_vendor_name';

$product->update_meta_data( '_custom_product_vendor_name', $vendor_name );
}
add_action( 'woocommerce_admin_process_product_object', 'action_woocommerce_admin_process_product_object', 10, 1 );

我想我找到了答案:

// Display Fields
add_action('woocommerce_product_options_general_product_data', 'woocommerce_product_custom_fields');
// Save Fields
add_action('woocommerce_process_product_meta', 'woocommerce_product_custom_fields_save');
function woocommerce_product_custom_fields()
{
global $woocommerce, $post;
$vendor_id      = $post->post_author;
$vendor_info    = get_userdata($vendor_id);
$vendor_name    = get_user_meta( $vendor_id, 'pv_shop_name', true );
echo '<div class="product_custom_field">';
// Custom Product Text Field
woocommerce_wp_text_input(
array(
'id'        => '_custom_product_vendor_name',
'placeholder'   => $vendor_name,
'value'         => $vendor_name,
'label'         => __('Vendor', 'woocommerce'),
'desc_tip'      => 'true'
)
);
echo '</div>';
}
function woocommerce_product_custom_fields_save($post_id)
{
// Custom Product Text Field
$woocommerce_custom_product_vendor_name = $_POST['_custom_product_vendor_name'];
if (!empty($woocommerce_custom_product_vendor_name))
update_post_meta($post_id, '_custom_product_vendor_name', esc_attr($woocommerce_custom_product_vendor_name));
}

该函数获取用户的元字段,并在保存后将其存储在数据库中。

最新更新