4 php wordpress metadata user-data woocommerce
对于 Woocommerce,在这个答案线程的帮助下,我在后端(管理员)用户列表中创建了一些自定义列:
在数据库中,有一些meta_key值调用billing_vatnr来自billing_companyWooCommerce 注册表并保存在wp_usermeta表中。
我想要弄清楚的是如何显示meta_value这些元键的对应项,并在每个用户各自的列中显示它们。
也就是说,在VAT Nr字段中,应该显示meta key的内容billing_vatnr,如果没有内容,则显示N/A。与 的公司名称列相同billing_company。
这是我到目前为止所尝试过的:
add_filter('manage_users_custom_column', 'vatnr_status_data', 10, 3);
function vatnr_status_data( $value, $column_name, $user_id ) {
if ( 'account_vatnr' == $column_name ) {
if( $billing_vatnr = get_user_meta( $user_id, 'billing_vatnr', true )) {
echo $billing_vatnr; } else { echo "N/A"; }
}
return $value;
}
Run Code Online (Sandbox Code Playgroud)
但这不起作用。
以下是我添加的不同列:
// creating the columns
add_action('manage_users_columns','account_verification_status_and_company_columns');
function account_verification_status_and_company_columns($column_headers) {
unset($column_headers['posts']);
$column_headers['account_verification'] = __('Verification Status');
$column_headers['account_vatnr'] = __('VAT Nr');
$column_headers['account_companyname'] = __('Company Name');
return $column_headers;
}
// fetching the verification status, thanks to LoicTheAztec
add_filter('manage_users_custom_column', 'user_account_verification_status_data', 10, 3);
function user_account_verification_status_data( $value, $column_name, $user_id ) {
if ( 'account_verification' == $column_name ) {
if( get_user_meta( $user_id, 'is_activated', true ) == 1 ) {
$value = '<span style="color:green;font-weight:bold;">Verified</span>';
} else {
$value = '<span class="na" style="color:grey;"><em>Not Verified</em></span>';
}
}
return $value;
}
Run Code Online (Sandbox Code Playgroud)
很感谢任何形式的帮助。
尝试以下稍微重新审视的代码,其中添加了一些内容account_vatnr和account_companyname其他自定义字段:
// Add custom columns to Admin users list
add_action('manage_users_columns', 'add_custom_users_columns', 10, 1 );
function add_custom_users_columns( $columns ) {
unset($columns['posts']);
$columns['account_verification'] = __('Verification Status');
$columns['account_vatnr'] = __('VAT Nr');
$columns['account_companyname'] = __('Company Name');
return $columns;
}
// fetching the verification status, thanks to LoicTheAztec
add_filter('manage_users_custom_column', 'add_data_to_custom_users_columns', 10, 3);
function add_data_to_custom_users_columns( $value, $column_name, $user_id ) {
if ( 'account_verification' == $column_name ) {
if( get_user_meta( $user_id, 'is_activated', true ) == 1 ) {
$value = '<span style="color:green;font-weight:bold;">Verified</span>';
} else {
$value = '<span class="na" style="color:grey;"><em>Not Verified</em></span>';
}
} elseif( 'account_vatnr' == $column_name ) {
if( $vat_nr = get_user_meta( $user_id, 'account_vatnr', true ) ) {
$value = '<span style="color:green;font-weight:bold;">' . $vat_nr . '</span>';
} else {
$value = '<span class="na" style="color:grey;"><em>N/a</em></span>';
}
} elseif( 'account_companyname' == $column_name ) {
if( $company = get_user_meta( $user_id, 'account_companyname', true ) ) {
$value = '<span style="color:green;font-weight:bold;">' . $company . '</span>';
} else {
$value = '<span class="na" style="color:grey;"><em>N/a</em></span>';
}
}
return $value;
}
Run Code Online (Sandbox Code Playgroud)
代码位于活动子主题(活动主题)的functions.php 文件中。经过测试并有效。
从数据库表中的注册数据来看wp_usermeta:
您将获得以下显示,如自定义列的管理员用户列表中所示:
| 归档时间: |
|
| 查看次数: |
4744 次 |
| 最近记录: |