There is an easy way to enable the checkout feature to upload files in WooCommerce without woocommerce_form_field. In this article, I'll show you two solutions to let customers add files in the WooCommerce checkout. One with the woocommerce_form_field function and action, and the second with a WooCommerce plugin in a step-by-step guide!
Have you ever asked your customers to send you additional emails with files, requirements for the order, or screenshots? It's quite tedious if you receive more orders, isn't it?
Wouldn't be great to save some time? Did you know that you can use the woocommerce_form_field function to add more fields to the WooCommerce checkout? What's more, there is a plugin that will let you add a file upload option during WooCommerce checkout in a few minutes!

You may also use the free version of the plugin to add custom WooCommerce checkout fields without the woocommerce_form_field function.
Contents
- Before showing you the woocommerce_form_field option
- Add the upload field with the woocommerce_form_field function
- Add file upload to WooCommerce checkout with a plugin
- Checkout files upload for WooCommerce (guide)
- Checkout files upload for WooCommerce (plugin vs woocommerce_form_field)
- How to allow customers to upload files with the File Upload field on the WooCommerce product page
- Simple Guide to Configure Custom Fields in WooCommerce Checkout
- Customize the WooCommerce Checkout Page: Top Tips for a Seamless Experience
- Customize the WooCommerce Checkout Page: Tips & Tools for Success
- Create Custom Fields in WooCommerce Checkout and Product Pages
Flexible Checkout Fields WooCommerce
Checkout files upload and custom fields for WooCommerce without the woocommerce_form_field function. It has never been easier with this checkout editor plugin. Check it out!
Download for free or Go to WordPress.orgNow, let's see the two methods to add custom fields to the WooCommerce checkout page (upload file example).
Before showing you the woocommerce_form_field option
First, I want to show you the final effect. I just want you to be sure that this is not what you are looking for before going to the woocommerce_form_field part.
- I'm using a WooCommerce plugin so that you'll not have to use the woocommerce_form_field function. The plugin lets you add the WooCommerce upload checkout field in a few moments:
 WooCommerce: add file upload to checkout That's it. It's now possible to send files during WooCommerce checkout!
- You can use CSS styling to further change the field's look. I'll tell you about that later.
- Also, look at the 'Here you can Upload the File'. This is the Label. Set your own, for example, describing the maximum image size that a customer can upload to the WooCommerce order.
- The method has endless possibilities. For example, you can change the label or create two WooCommerce checkout file upload fields in a row:
 WooCommerce upload files during checkout 
- Also, you can use an additional checkbox, just like I did without the woocommerce_form_field custom code:
 Checkout files upload for WooCommerce : the final result 
- Your customers will see which image they upload to the WooCommerce order:
 WooCommerce upload image to order - this is what your customers will see at checkout 
- Of course, you can limit what type of files (like an image) they can upload to the WooCommerce order. Also, you can set the maximum file size. Here is the error message for the excluded file types:
- Now, a few words about the design. I use the default WooCommerce theme: Storefront. That's why my checkout page looks so raw and so does the WooCommerce upload checkout field.But you can use CSS styling for this and any other fields. Look how I changed the look of the upload file field:
 Add CSS to the checkout files upload for WooCommerce 
- Once the customer uploads a file, you can see it in the Order details screen:
That was a quick look at how to add the file upload option to the WooCommerce checkout.
Add the upload field with the woocommerce_form_field function
If you'd rather add custom fields to the WooCommerce order, you may use a built-in function and actions.
The information below is a short introduction (you can find more info about form fields here).
- You may use the woocommerce_form_field( $key, $args, $value = null ) function to prepare a new field for the WooCommerce checkout. For example, to add a simple input field you need to specify the $args element like that:
woocommerce_form_field( 'participant', array( 
 'type' => 'text',
 'required' => true,
 'label' => 'Participant',
 'description' => 'Please enter the full name of the workshop participant',
 ));
 
- Then, you can use that function to add the new field to the WooCommerce checkout (in the billing section with a WooCommerce action). You can add such a piece of code in your theme's functions.php file (at the end before the ?> tag if there is one). Please remember to add the code again after updating or changing your WordPress theme.
add_action( 'woocommerce_after_checkout_billing_form', 'add_a_custom_field' ); function add_a_custom_field(){ woocommerce_form_field( 'participant', array( 
 'type' => 'text',
 'required' => true,
 'label' => 'Participant',
 'description' => 'Please enter the full name of the workshop participant',
 ));
 }
 
- Your WooCommerce checkout will get the new field thanks to the woocommerce_form_field function and the action!
I hope that it will be a good starting point for WC checkout customization with woocommerce_form_field.
Add file upload to WooCommerce checkout with a plugin
Standard WooCommerce doesn't let you add an upload checkout field. Also, you won't be able to customize your checkout the way you want to. That's why we created the Flexible Checkout Fields.
People love the plugin. Almost 90,000 stores use it daily!
You can use it to create a WooCommerce upload checkout field. However, you can do much more with this plugin!
In general, Flexible Checkout Fields lets you:
- easily add custom fields to the checkout,
- edit the present ones,
- rearrange fields in the checkout
- and much more!
Also, read how to add custom fields to your WooCommerce order form for FREE →
You can download this plugin for free but you will need the PRO version. We limited the free version to these types of custom fields:
- Text
- Textarea
- Number
- Phone
- URL
- Checkbox
- Color
- Headline
- Paragraph
- Image
- HTML
However, check out this plugin for free before you buy! We have prepared a video, which will serve you as a sneak peeks of what you will find in the free version, have a look:
Flexible Checkout Fields WooCommerce
Checkout files upload and custom fields for WooCommerce without the woocommerce_form_field function. It has never been easier with this checkout editor plugin. Check it out!
Download for free or Go to WordPress.orgCheckout files upload for WooCommerce (guide)
Let's start with the configuration. Please note: this feature is available in the PRO version of the plugin.
- First, go to WooCommerce → Checkout Fields:

2. You will see the Billing section. You can edit this section or add a new field.

3. Now you need to
- choose a File Upload field type,
- then enter the field Label,
- finally, click Add Field.
4. Next, select the new field in the Edit section column. You can set here the:
- Allowed file types
- and Maximum file size

You can also set your own Validation. How? Check out our WooCommerce Checkout Validation Guide →
5. The next option is the Appearance:

That is optional, of course. You can provide any CSS Class here. This way you can set styling for the field.
What hovers behind the Conditional logic tab? Its settings, of course 😉

I cover this topic in the WooCommerce Checkout Conditional Fields →
Checkout files upload for WooCommerce (plugin vs woocommerce_form_field)
Today, you have learned how to implement the upload field for WooCommerce checkout with a plugin or use the woocommerce_form_field function instead. I hope that uploading files during WooCommerce checkout will save you a lot of time. No matter which solution you use!
You might have also learned how to add the upload field to the WooCommerce checkout without woocommerce_form_field.
Let me know how are you going to use that field!
Also, if you need more tips about checkout configuration, use our WooCommerce Checkout Settings Guide →
If you want to test the PRO field types for WooCommerce Checkout, try the Flexible Checkout Fields in a free demo!









