在WooCommerce网站的结帐页面上更新运费

时间:2017-05-19 08:51:08

标签: ajax wordpress cookies woocommerce

我们正在使用自定义代码,以允许最终用户选择其投放的城市,日期和时间。交付率应根据城市而​​变化。城市选择框位于结帐页面。

更改城市会触发ajax,成功更改订单审核部分下显示的投放费用。到现在为止还挺好。 不幸的是,提交订单后价格没有达到订单。它在某个地方迷失了。

提示可能是因为同一个城市选择框也在产品页面上,如果用户在添加到购物车时选择了它,然后进入结帐,则会显示交付率提交订单时不会丢失。

是否需要触发任何刷新才能更新运费?

更新费率的功能(成功)

function adjust_shipping_rate( $rates ){
    global $woocommerce;

        foreach ($rates as $rate) {
            $cost = $rate->cost;
            $rate->cost = $_COOKIE['shipping_city_cost'];
        }
        return $rates;
}
add_filter( 'woocommerce_package_rates', 'adjust_shipping_rate', 50, 1 );

更新21-05-2017

这是cookie的更新方式:更改选择框后,将触发async ajax调用并执行以下PHP代码。

function get_and_set_shipping_rate(){
    $shipping_city = $_POST['city'];
    $shipping_cost = get_shipping_cost_by_city($shipping_city);
    setcookie('shipping_city_cost', $shipping_cost, time() + (86400 * 30), '/'); 
    $_COOKIE['shipping_city_cost'] = $shipping_cost;
    echo 'Shipping cost updated: '.$shipping_city.' : '.$shipping_cost;
}

add_action( 'wp_ajax_get_and_set_shipping_rate', 'get_and_set_shipping_rate' );
add_action( 'wp_ajax_nopriv_get_and_set_shipping_rate', 'get_and_set_shipping_rate' );

以下是ajax调用:

jQuery(document).on('change', '#shipping_delivery_city', function(){
     var requested_city = jQuery(this).val();
        var data = {
                'action': 'get_and_set_shipping_rate',
                'city': requested_city
            };

            jQuery.ajax({
                type: "POST",
                url: shipping_dates.ajax_url,
                data: data,
                async: false,
                success: function (response) {
                    console.log(response);
                }
            });
});

1 个答案:

答案 0 :(得分:1)

有了这个,我有两个假设。 1.)您在结帐页面上使用此代码。 2.)您已经拥有自己的函数get_shipping_cost_by_city

add_action( 'woocommerce_checkout_update_order_review', 'woocommerce_checkout_update_order_review' );
function woocommerce_checkout_update_order_review( $post_data ){

    $data = array();
    $vars = explode('&', $post_data);
    foreach ($vars as $k => $value){
        $v = explode('=', urldecode($value));
        $data[$v[0]] = $v[1];
    }
    $shipping_cost = get_shipping_cost_by_city( $data['billing_city'] );
    WC()->session->set( 'shipping_city_cost', $shipping_cost );
    foreach ( WC()->cart->get_shipping_packages() as $package_key => $package ) {
        // this is needed for us to remove the session set for the shipping cost. Without this, we can't set it on the checkout page.
        WC()->session->set( 'shipping_for_package_' . $package_key, false );
    }

}

add_filter( 'woocommerce_package_rates', 'adjust_shipping_rate', 50 );
function adjust_shipping_rate( $rates ){

    foreach ($rates as $rate) {
        $cost = $rate->cost;
        $rate->cost = WC()->session->get( 'shipping_city_cost' );
    }
    return $rates;
}

shipping_city_cost的设置/获取由WC()->session->setWC()->session->get完成。我不需要为woocommerce_checkout_update_order_review设置一个ajax函数,只要在结帐页面上完成更新,就会在ajax调用中添加一个动作挂钩。

对于这个测试,我使用这个函数:

function get_shipping_cost_by_city( $city ) {
    if ( $city == 'Ormoc City' ){
        return 100;
    }
    return 130;
}