24

バリエーションドロップダウン内に製品バリエーション価格を表示しようとしています。ドロップダウンでバリエーションを選択すると、価格が 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();
}

すべてのオプションの最小変動価格を取得するだけです。各バリエーションの価格を取得したい。どんな手掛かり?

4

5 に答える 5

46

ここにあなたが探しているコードがあります

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;

    $id = $product->get_id();

    $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 = $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;

}

これが役立つことを願っています。

于 2012-09-05T21:26:27.747 に答える
22

これは皆さんを助けるかもしれません。WCの新しいバージョンで同じことをする方法を探している間:

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

私は ajax を使用しており、post メソッドでバリエーションの ID を渡しています。

于 2014-12-03T18:45:07.993 に答える
4

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' ";

これでエラーはなくなりました。エラーログはきれいで空のままです。

他の誰かが問題に遭遇した場合に備えて共有したかっただけです。

于 2013-03-17T05:41:51.277 に答える