it-roy-ru.com

WooCommerce получить изменение цены продукта

Я пытаюсь отобразить цену варианта продукта в раскрывающемся списке вариантов. Я пытаюсь изменить поведение по умолчанию, когда цена отображается внутри элемента div, когда вы выбираете вариант в раскрывающемся списке.

Проблема в том, что я не могу найти, где этот div получает цену вариации. Я искал весь JavaScript, но не смог найти его

Если я использую:

add_filter('woocommerce_variation_option_name' ,'add_price_to_dropdown');

function add_price_to_dropdown($name){

    global $product;
    return $name.' '.$product->get_price_html();
}

Я просто получаю минимальную цену за все варианты. Я хочу получить цену за каждый вариант. Любая подсказка?

17
chifliiiii

Вот код, который вы ищете

add_filter( 'woocommerce_variation_option_name', 'display_price_in_variation_option_name' );

function display_price_in_variation_option_name( $term ) {
    global $wpdb, $product;

    if ( empty( $term ) ) return $term;
    if ( empty( $product->id ) ) return $term;

    $result = $wpdb->get_col( "SELECT slug FROM {$wpdb->prefix}terms WHERE name = '$term'" );

    $term_slug = ( !empty( $result ) ) ? $result[0] : $term;

    $query = "SELECT postmeta.post_id AS product_id
                FROM {$wpdb->prefix}postmeta AS postmeta
                    LEFT JOIN {$wpdb->prefix}posts AS products ON ( products.ID = postmeta.post_id )
                WHERE postmeta.meta_key LIKE 'attribute_%'
                    AND postmeta.meta_value = '$term_slug'
                    AND products.post_parent = $product->id";

    $variation_id = $wpdb->get_col( $query );

    $parent = wp_get_post_parent_id( $variation_id[0] );

    if ( $parent > 0 ) {
         $_product = new WC_Product_Variation( $variation_id[0] );
         return $term . ' (' . wp_kses( woocommerce_price( $_product->get_price() ), array() ) . ')';
    }
    return $term;

}

Надеюсь, это будет полезно.

38
Ratnakar - StoreApps

Это может помочь вам, ребята; при поиске, как сделать то же самое с новой версией WC:

global $woocommerce;
$product_variation = new WC_Product_Variation($_POST['variation_id']);
$regular_price = $product_variation->regular_price;

Я использую ajax и передаю идентификатор варианта с помощью метода post.

12
numediaweb

У меня был точно такой же вопрос, как и у ОП, но мой случай был немного другим. Вот мое решение, которое может помочь другим, кто также попадает на эту страницу.

function get_product_variation_price($variation_id) {
    $product = new WC_Product_Variation($variation_id);
    return $product->product_custom_fields['_price'][0];
}

ОБНОВЛЕНИЕ для WooCommerce 2.2.10: Приведенный выше код не работает в текущей версии WooCommerce. Этот код, приведенный ниже, работает и заслуживает рассмотрения, поскольку он использует API WooCommerce, он избегает ручных запросов SQL и довольно прост ...

/*
 * You can find the $variation_id in the Product page (go to Product Data > Variations, and it is shown with a preceeding "#" character)
 */
function get_product_variation_price($variation_id) {

    global $woocommerce; // Don't forget this!
    $product = new WC_Product_Variation($variation_id);
    //return $product->product_custom_fields['_price'][0]; // No longer works in new version of WooCommerce
    //return $product->get_price_html(); // Works. Use this if you want the formatted price
    return $product->get_price(); // Works. Use this if you want unformatted price

}
4
ban-geoengineering

Я использовал этот код в Woocommerce, чтобы показать свои цены на варианты, и когда я обновил Woocommerce 2.0, я обнаружил ошибки базы данных, которые появлялись в wp-admin/error-log при каждом редактировании продукта. Я не уверен, что ошибки также возникали до обновления до 2.0, потому что я не использовал Woocommerce задолго до обновления и не думаю, что проверял журнал ошибок до сегодняшнего дня. 

Цены вариаций отображались как ожидалось, но журнал ошибок заполнялся следующей ошибкой каждый раз, когда я открывал продукт для редактирования. Произошла ошибка для каждого варианта, связанного с продуктом, который я редактировал. 

WordPress database error You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 8 for query SELECT postmeta.post_id AS product_id
            FROM wp_postmeta AS postmeta
                LEFT JOIN wp_posts AS products ON ( 

products.ID = postmeta.post_id )
            WHERE postmeta.meta_key LIKE 'attribute_%'
                AND postmeta.meta_value = '12'
                AND products.post_parent =  made by 

include('wp-admin/edit-form-advanced.php'), do_meta_boxes, call_user_func, woocommerce_product_data_box, do_action('woocommerce_product_write_panels'), call_user_func_array, variable_product_type_options, include('/plugins/woocommerce/admin/post-types/writepanels/variation-admin-html.php'), apply_filters('woocommerce_variation_option_name'), call_user_func_array, display_price_in_variation_option_name

Я изменил следующую строку в вашем коде: AND products.post_parent = $ product-> id "; To this AND products.post_parent = '$ product-> id'";

и теперь ошибок больше нет. Журнал ошибок остается красивым и пустым.

Просто хотел поделиться, если кто-то еще столкнулся с проблемой.

4
Janine

Мой взгляд на этот вопрос, работающий в последней версии Woocommerce: 3.2.1 (октябрь 2017 г.) Цена будет отображаться рядом с вариацией в раскрывающемся списке.

add_filter( 'woocommerce_variation_option_name', 'display_price_in_variation_option_name' );

function display_price_in_variation_option_name( $term ) {
    global $wpdb, $product;

    $result = $wpdb->get_col( "SELECT slug FROM {$wpdb->prefix}terms WHERE name = '$term'" );

    $term_slug = ( !empty( $result ) ) ? $result[0] : $term;


    $query = "SELECT postmeta.post_id AS product_id
                FROM {$wpdb->prefix}postmeta AS postmeta
                    LEFT JOIN {$wpdb->prefix}posts AS products ON ( products.ID = postmeta.post_id )
                WHERE postmeta.meta_key LIKE 'attribute_%'
                    AND postmeta.meta_value = '$term_slug'
                    AND products.post_parent = $product->id";

    $variation_id = $wpdb->get_col( $query );

    $parent = wp_get_post_parent_id( $variation_id[0] );

    if ( $parent > 0 ) {
        $_product = new WC_Product_Variation( $variation_id[0] );
        $_currency = get_woocommerce_currency_symbol();
        return $term . ' ('.$_currency.' '. $_product->get_price()  . ')';
    }
    return $term;

}

Надеюсь, что это поможет кому-то . Добавьте это в вашей дочерней теме functions.php

0
Cynthia Lara