ホームページ >バックエンド開発 >PHPチュートリアル >WooCommerce Checkout のラジオ ボタンの選択に基づいて動的な料金調整を実装するにはどうすればよいですか?

WooCommerce Checkout のラジオ ボタンの選択に基づいて動的な料金調整を実装するにはどうすればよいですか?

DDD
DDDオリジナル
2024-10-20 17:58:31501ブラウズ

How to Implement Dynamic Fee Adjustments Based on Radio Button Selections in WooCommerce Checkout?

WooCommerce Checkout のラジオ ボタンに基づいて料金を動的に更新する

はじめに

ラジオ ボタンの選択に基づいて料金を動的に更新できるようにすることで、WooCommerce チェックアウト エクスペリエンスを強化します。これにより、顧客の好みに合わせて、さまざまな梱包オプションと料金を提供できます。

コードの実装

必要な機能を実現するには、functions.php ファイルに次のコードを実装します。

<code class="php">// Add a custom dynamic packaging fee
add_action( 'woocommerce_cart_calculate_fees', 'add_packaging_fee', 20, 1 );
function add_packaging_fee( $cart ) {
    if ( is_admin() &amp;&amp; ! defined( 'DOING_AJAX' ) )
        return;

    $packing_fee = WC()->session->get( 'chosen_packing' ); // Dynamic packing fee
    $fee = $packing_fee === 'box' ? 9.00 : 3.00;
    $cart->add_fee( __( 'Packaging fee', 'woocommerce' ), $fee );
}

// Add a custom radio fields for packaging selection
add_action( 'woocommerce_review_order_after_shipping', 'checkout_shipping_form_packing_addition', 20 );
function checkout_shipping_form_packing_addition() {
    $domain = 'woocommerce';

    echo '<tr class="packing-select"><th>' . __('Packing options', $domain) . '</th><td>';

    $chosen   = WC()->session->get('chosen_packing');
    $chosen   = empty($chosen) ? WC()->checkout->get_value('radio_packing') : $chosen;
    $chosen   = empty($chosen) ? 'bag' : $chosen;

    // Add a custom checkbox field
    woocommerce_form_field( 'radio_packing', array(
        'type' => 'radio',
        'class' => array( 'form-row-wide packing' ),
        'options' => array(
            'bag' => __('In a bag '.wc_price(3.00), $domain),
            'box' => __('In a gift box '.wc_price(9.00), $domain),
        ),
        'default' => $chosen,
    ), $chosen );

    echo '</td></tr>';
}</code>

JavaScript と AJAX スクリプト

ラジオ ボタンの選択時にシームレスに更新できるようにするには、次の JavaScript と AJAX スクリプトを実装します。

<code class="javascript">// jQuery - Ajax script
add_action( 'wp_footer', 'checkout_shipping_packing_script' );
function checkout_shipping_packing_script() {
    if ( ! is_checkout() )
        return; // Only checkout page
    ?>
    <script type="text/javascript">
    jQuery( function($){
        $('form.checkout').on('change', 'input[name=radio_packing]', function(e){
            e.preventDefault();
            var p = $(this).val();
            $.ajax({
                type: 'POST',
                url: wc_checkout_params.ajax_url,
                data: {
                    'action': 'woo_get_ajax_data',
                    'packing': p,
                },
                success: function (result) {
                    $('body').trigger('update_checkout');
                    console.log('response: '+result); // just for testing | TO BE REMOVED
                },
                error: function(error){
                    console.log(error); // just for testing | TO BE REMOVED
                }
            });
        });
    });
    </script>
    <?php

}

// Php Ajax (Receiving request and saving to WC session)
add_action( 'wp_ajax_woo_get_ajax_data', 'woo_get_ajax_data' );
add_action( 'wp_ajax_nopriv_woo_get_ajax_data', 'woo_get_ajax_data' );
function woo_get_ajax_data() {
    if ( isset($_POST['packing']) ){
        $packing = sanitize_key( $_POST['packing'] );
        WC()->session->set('chosen_packing', $packing );
        echo json_encode( $packing );
    }
    die(); // Alway at the end (to avoid server error 500)
}</code>

Notes

  • このコードがアクティブな子テーマに追加されるか、テーマの function.php ファイルに直接追加されていることを確認してください。
  • 提供されたコードは、ログインしていないユーザーを考慮しており、最新の WooCommerce バージョン (3.7.x) と互換性があります。 .
  • 問題が発生した場合は、ラジオ ボタンと梱包オプションに関連する以前のカスタマイズをすべて削除してください。

以上がWooCommerce Checkout のラジオ ボタンの選択に基づいて動的な料金調整を実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。