Site Overlay

Change the Billing fields position in CheckoutWC

In the WooCommerce standard checkout form, you are first asked for personal details like First Name, Last Name, Email Address, etc. Then, immediately you are asked to fill up the Billing Address. That’s nice in some cases, but it can be improved.

CheckoutWC, by design, changes this behavior by switching priorities between the Billing Address and Shipping Address, being the Shipping Address the first option right after the customer’s personal details.

The not-so-good thing is that, by default, it sends the Billing Address option right to the last step.

And there aren’t any options in the CheckoutWC settings to customize the field position.

However, it can still be changed with a bit of code.

So first things first, you need to identify where the Billing Address fields are on the checkout page.

Then, decide on a place to move it.

For this example, let’s move the Billing Address fields to the first step in the checkout page, which is the Information tab.

The destination place will be right below the Shipping Address.

Let’s lay out the steps you need to make the change.

First, “unhook” the Billing Address fields from the Payment tab.

remove_action( 'cfw_checkout_payment_method_tab', 'cfw_payment_tab_content_billing_address', 20 ); 

Second, hook it after the Shipping Address.

add_action( 'cfw_checkout_after_shipping_address', 'cfw_payment_tab_content_billing_address' );

That’s all! It’s that simple.

2 thoughts on “Change the Billing fields position in CheckoutWC

  1. Thank you! This was very helpful! To be honest I didn’t read the article, just took the code and applied it and it worked like a charm. Yet I had to apply a small CSS to add some maring at the top of the header because it was too close to the delivery fields.

    Did it like this: (requires !important due to other rules added by plugin)
    .cfw-billing-address-heading {
    margin-top: 1em!imporant;
    }

    1. That’s so cool, Cristian.

      I’m glad the article was of help to you, even you went straight to the code and that it worked a treat.

      Thank you for taking the time to share your experience and the CSS snippet. It may be useful to other people.

      Best,
      Juan

Leave a Reply

Your email address will not be published. Required fields are marked *