在woocommerce的结帐页面显示更新的数据

Vig*_*ani 9 php wordpress woocommerce

问题可能很奇怪:(

我试图通过短码来显示折扣的一些信息结帐页面woocommerce有钩的woocommerce_before_checkout_form.如果我在购物车页面应用的优惠券,并参观结账注意到挂钩的消息显示了打折的正确值,但结账如果我删除/添加没有出现在那个woocommerce_before_checkout_form钩子我尝试通过删除和添加该钩子但仍然短码值没有更新,我测试了多次与以下功能可以任何人有一些工作的想法/建议将是伟大的

<?php

/*
 * Plugin Name: Hook Priority
 *
 */

function add_my_shortcode() {
    ob_start();
    global $woocommerce;
    echo $woocommerce->cart->discount_cart;
    return ob_get_clean();
}

add_shortcode('my_shortcode', 'add_my_shortcode');

function add_message_in_checkout() {
    var_dump(do_shortcode('[my_shortcode]'));
}

add_action('woocommerce_before_checkout_form', 'add_message_in_checkout');

function coupon_removed_function( $coupon_code ) {

    remove_all_actions('woocommerce_before_checkout_form');
    remove_shortcode('my_shortcode');
    do_action('woocommerce_before_checkout_form');
}

add_action("woocommerce_removed_coupon", 'coupon_removed_function');
Run Code Online (Sandbox Code Playgroud)

我尝试使用javascript重新加载页面(刷新实例)并且它正在工作,我不想使用那个,除非没有本机wordpress/php解决方案需要克服.

echo "<script type='text/javascript'>location.reload();</script>";
Run Code Online (Sandbox Code Playgroud)

我身边目前发生的事情是

我从购物车添加了10美元的折扣,然后在结帐时,我可以看到10美元的价值,但如果我从结帐中删除优惠券它仍然显示10美元但它应该是0美元.

提前致谢.

Roh*_*ner 4

您可以使用jQuery来实现您的结果。

方法 :

WooCommerceupdated_checkout几乎每次结账页面发生任何事情时都会触发 jQuery 事件。因此您可以利用该事件来实现您想要的结果。

修改当前代码:

1)首先添加,JS以便我们可以jQuery在该 JS 文件中进行编码。

因此,修改后您的代码将如下所示:

自定义插件.php

<?php

/*
 * Plugin Name: Hook Priority
 *
 */

function add_my_shortcode() {
    ob_start();
    global $woocommerce;
    echo $woocommerce->cart->discount_cart;
    return ob_get_clean();
}

add_shortcode('my_shortcode', 'add_my_shortcode');

function add_message_in_checkout() {
    //var_dump(do_shortcode('[my_shortcode]'));
    /*Modification*/
    echo '<div class="coupon_value">'.do_shortcode('[my_shortcode]').'</div>'; // Here I have modified it to give class and update value
}

add_action('woocommerce_before_checkout_form', 'add_message_in_checkout');

function coupon_removed_function( $coupon_code ) {

    remove_all_actions('woocommerce_before_checkout_form');
    remove_shortcode('my_shortcode');
    do_action('woocommerce_before_checkout_form');
}

add_action("woocommerce_removed_coupon", 'coupon_removed_function');

/*Modifications starts from here*/

/*Action to enqueue Jjavascript in Footer*/
add_action("wp_footer", 'enqueue_plugin_script');

function enqueue_plugin_script(){
    /*Enqueue Custom Javascript to use*/
    wp_enqueue_script( 'custom-script', plugin_dir_url( __FILE__ ).'custom.js', array( 'jquery' ), '1.0.0', true );
    /*Localize parameter to use in JS file*/
    wp_localize_script( 'custom-script', 'custom_values', array(
        'ajaxurl'   => admin_url( 'admin-ajax.php' ),
        'token'     => wp_create_nonce( 'token' )
    ));
}

/*AJAX Event to check for discount*/
add_action('wp_ajax_check_for_coupon', 'check_for_coupon');
add_action('wp_ajax_nopriv_check_for_coupon', 'check_for_coupon');

function check_for_coupon(){
    global $woocommerce;
    $send_json = array();
    $send_json = array('success'=>false);
    if($woocommerce->cart->discount_cart){
        $send_json = array('success'=>true, 'discount'=>$woocommerce->cart->discount_cart);
    }
    wp_send_json($send_json);
    die();
}
Run Code Online (Sandbox Code Playgroud)

自定义.js

/*
 * custom.js
 * @author : Rohil Mistry
 */

(function($){
    $(document).ready(function(){
        /*updated_checkout event*/
        $(document.body).on('updated_checkout', function(){
            /*Make an AJAX call on updated_checkout event*/
            $.ajax({
                type:       'POST',
                url:        custom_values.ajaxurl,
                data:       {action:'check_for_coupon'},
                success:    function( result ) {
                    console.info(result);
                    if(result.success){
                        $(".coupon_value").html(result.discount);
                    }
                    else{
                        $(".coupon_value").html('');
                    }
                }
            });
        });
    });
})(jQuery);
Run Code Online (Sandbox Code Playgroud)

在代码中找到我的内联注释以了解代码。

如果您有任何疑问,请告诉我。