簡體   English   中英

在WooCommerce中定義用戶變量我的賬戶自定義菜單項內容

[英]Define user variable in WooCommerce My account custom menu item content

自定義菜單顯示在 woocommerce 的我的帳戶中。
我正在使用下面的代碼制作自定義菜單。

/**
 * Query registration
 */
function my_custom_query_vars($vars)
{
    $vars[] = 'my-dosu-endpoint';
    return $vars;
}
add_filter('query_vars', 'my_custom_query_vars', 0);

function my_custom_my_account_menu_items($items)
{
    $items['my-dosu-endpoint'] = __('OOOO', 'woocommerce');
    return $items;
}
add_filter('woocommerce_account_menu_items', 'my_custom_my_account_menu_items');

function my_custom_endpoint_content()
{
}

add_action('woocommerce_account_my-dosu-endpoint_endpoint', 'my_custom_endpoint_content');


function my_custom_endpoint_title($title)
{
    global $wp_query;
    $is_endpoint = isset($wp_query->query_vars['my-dosu-endpoint']);
    if ($is_endpoint && !is_admin() && is_main_query() && in_the_loop() && is_account_page()) {
        // New page title.
        $title = __('OOOO', 'woocommerce');
        remove_filter('the_title', 'my_custom_endpoint_title');
    }
    return $title;
}
add_filter('the_title', 'my_custom_endpoint_title');

我想在這個自定義菜單中顯示用戶信息注冊表。

我能夠復制並粘貼form-edit-acount.php的內容並使用以下內容顯示它:

function my_custom_endpoint_content()
{
    defined('ABSPATH') || exit;

    do_action('woocommerce_before_edit_account_form'); ?>

    <form class="woocommerce-EditAccountForm edit-account" action="" method="post" <?php do_action('woocommerce_edit_account_form_tag'); ?>>

        <?php do_action('woocommerce_edit_account_form_start'); ?>

        <p class="woocommerce-form-row woocommerce-form-row--first form-row form-row-first">
            <label for="account_first_name"><?php esc_html_e('First name', 'woocommerce'); ?>&nbsp;<span class="required">*</span></label>
            <input type="text" class="woocommerce-Input woocommerce-Input--text input-text" name="account_first_name" id="account_first_name" autocomplete="given-name" value="<?php echo esc_attr($user->first_name); ?>" />
        </p>
        <p class="woocommerce-form-row woocommerce-form-row--last form-row form-row-last">
            <label for="account_last_name"><?php esc_html_e('Last name', 'woocommerce'); ?>&nbsp;<span class="required">*</span></label>
            <input type="text" class="woocommerce-Input woocommerce-Input--text input-text" name="account_last_name" id="account_last_name" autocomplete="family-name" value="<?php echo esc_attr($user->last_name); ?>" />
        </p>
        <div class="clear"></div>

        <p class="woocommerce-form-row woocommerce-form-row--wide form-row form-row-wide">
            <label for="account_display_name"><?php esc_html_e('Display name', 'woocommerce'); ?>&nbsp;<span class="required">*</span></label>
            <input type="text" class="woocommerce-Input woocommerce-Input--text input-text" name="account_display_name" id="account_display_name" value="<?php echo esc_attr($user->display_name); ?>" /> <span><em><?php esc_html_e('This will be how your name will be displayed in the account section and in reviews', 'woocommerce'); ?></em></span>
        </p>
        <div class="clear"></div>

        <p class="woocommerce-form-row woocommerce-form-row--wide form-row form-row-wide">
            <label for="account_email"><?php esc_html_e('Email address', 'woocommerce'); ?>&nbsp;<span class="required">*</span></label>
            <input type="email" class="woocommerce-Input woocommerce-Input--email input-text" name="account_email" id="account_email" autocomplete="email" value="<?php echo esc_attr($user->user_email); ?>" />
        </p>

        <fieldset>
            <p class="woocommerce-form-row woocommerce-form-row--wide form-row form-row-wide">
                <label for="password_current"><?php esc_html_e('Current password (leave blank to leave unchanged)', 'woocommerce'); ?></label>
                <input type="password" class="woocommerce-Input woocommerce-Input--password input-text" name="password_current" id="password_current" autocomplete="off" />
            </p>
            <p class="woocommerce-form-row woocommerce-form-row--wide form-row form-row-wide">
                <label for="password_1"><?php esc_html_e('New password (leave blank to leave unchanged)', 'woocommerce'); ?></label>
                <input type="password" class="woocommerce-Input woocommerce-Input--password input-text" name="password_1" id="password_1" autocomplete="off" />
            </p>
            <p class="woocommerce-form-row woocommerce-form-row--wide form-row form-row-wide">
                <label for="password_2"><?php esc_html_e('Confirm new password', 'woocommerce'); ?></label>
                <input type="password" class="woocommerce-Input woocommerce-Input--password input-text" name="password_2" id="password_2" autocomplete="off" />
            </p>
        </fieldset>
        <div class="clear"></div>

        <?php do_action('woocommerce_edit_account_form'); ?>

        <p>
            <?php wp_nonce_field('save_account_details', 'save-account-details-nonce'); ?>
            <button type="submit" class="woocommerce-Button button" name="save_account_details" value="<?php esc_attr_e('Save changes', 'woocommerce'); ?>"><?php esc_html_e('Save changes', 'woocommerce'); ?></button>
            <input type="hidden" name="action" value="save_account_details" />
        </p>

        <?php do_action('woocommerce_edit_account_form_end'); ?>
    </form>

<?php do_action('woocommerce_after_edit_account_form');
}

add_action('woocommerce_account_my-dosu-endpoint_endpoint', 'my_custom_endpoint_content');

但是我一直無法獲取用戶信息。

因此,它對應於保存時的非輸入檢查。
“未定義的變量$user ”顯示在$user部分。 我應該在哪里定義它?

首先在你的最后一個 function, defined('ABSPATH') || exit; defined('ABSPATH') || exit; 是不必要的,這是由 php 或模板文件使用的。 然后你需要定義$user變量,它是WP_User object(當前用戶)的一個實例。

所以只需替換defined('ABSPATH') || exit; defined('ABSPATH') || exit; $user = wp_get_current_user(); .

它應該解決“未定義的變量$user問題。

在 function 的開頭:

$user = wp_get_current_user();

如果該代碼不起作用,那么這個代碼應該可以解決問題:

$user = get_userdata( get_current_user_id() );

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM