Товарная цена Woocommerce
Im пытается показать цену изменения продукта внутри раскрывающегося списка вариантов.
Я пытаюсь изменить поведение по умолчанию, когда цена отображается внутри 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();
}
Я просто получаю минимальную цену изменения для всех вариантов. Я хочу получить цену за каждую вариацию. Любая подсказка?
Ответы
Ответ 1
Вот код, который вы ищете
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;
}
Надеюсь, это будет полезно.
Ответ 2
Это может помочь вам, ребята; при поиске, как сделать то же самое с новой версией WC:
global $woocommerce;
$product_variation = new WC_Product_Variation($_POST['variation_id']);
$regular_price = $product_variation->regular_price;
Я использую ajax и передаю идентификатор варианта с методом post.
Ответ 3
Я использую этот код в 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 ";
к этому AND products.post_parent = '$ product- > id' ";
и теперь больше нет ошибок. Журнал ошибок остается красивым и пустым.
Просто хотел поделиться тем, что кто-то другой столкнулся с проблемой.
Ответ 4
У меня был точно такой же вопрос, как и у OP, но мой случай был немного другим. Вот мое решение, которое может помочь другим, которые также приземляются на этой странице.
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
}
Ответ 5
Я беру эту проблему, работая в последней 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;
}