Magento 2 provides a highly flexible platform for ecommerce businesses. However, not every field in the default checkout process is necessary for all store owners. Fields such as city, telephone, and company may not be required for every type of business or could clutter the user experience.
Magento 2 checkout is the process of removing unwanted fields from both the shipping and billing address forms. This blog post will guide you on how to remove these fields from your checkout pages.
ON THIS PAGE
Magento 2 Checkout by Removing Unnecessary Address Fields [An Overview]
Removing unnecessary fields from the checkout process in Magento 2 can improve the user experience by simplifying the checkout flow and reducing friction. For businesses that don’t need specific address fields like city, company, or telephone, eliminating them will streamline the form and lead to higher conversion rates.
If you’re aiming to create a more straightforward checkout for digital goods, streamline the data collection process, and simply prefer a minimal approach, Magento 2 offers several methods to hide or remove address fields from the checkout.
Recommended Read: Top 7 Magento Solution Partners in 2025 [ +FAQs]
Steps to Remove the Fields in the Shipping and Billing Address Form
1. Create a Custom Module
app/code/DCKAP/Popup/etc/module.xml and app/code/DCKAP/Popup/registration.php
registration.php
<?php
\Magento\Framework\Component\ComponentRegistrar::register(
\Magento\Framework\Component\ComponentRegistrar::MODULE,
'DCKAP_Popup',
__DIR__
);
Module.xml
<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:Module/etc/module.xsd">
<module name="DCKAP_Popup" setup_version="1.0.0" />
</config>
2) Create di.xml
app/code/DCKAP/Popup/etc/frontend/di.xml
<?xml version="1.0" ?>
<!--
/**
* Created By : Rathinapranesh
*/
-->
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="urn:magento:framework:ObjectManager/etc/config.xsd">
<type name="Magento\Checkout\Block\Checkout\LayoutProcessor">
<plugin name="remove_company_from_checkout"
type="DCKAP\Popup\Plugin\Checkout\LayoutProcessor"
sortOrder="10"/>
</type>
<type name="Magento\Checkout\Block\Checkout\LayoutProcessor">
<plugin name="remove_checkout_billing_address_fields"
type="DCKAP\Popup\Plugin\Checkout\BillingAddressLayoutProcessor" sortOrder="1"/>
</type>
</config>
Also Read: How to Add Product to Cart with a Custom Option in Magento 2?
3) create BillingAddressLayoutProcessor.php
app/code/DCKAP/Popup/Plugin/Checkout/BillingAddressLayoutProcessor.php
<?php
namespace DCKAP\Popup\Plugin\Checkout;
use Magento\Checkout\Block\Checkout\LayoutProcessor;
class BillingAddressLayoutProcessor
{
public function afterProcess(
LayoutProcessor $subject,
array $result
)
{
// Access the configuration of the billing form fields
$billingConfiguration = &$result['components']['checkout']['children']['steps']['children']['billing-step']
['children']['payment']['children']['payments-list']['children'];
if (isset($billingConfiguration)) {
// Loop through each field in the billing form
foreach ($billingConfiguration as $key => &$billingForm) {
// Skip fields that are not form-related
if (!isset($billingForm['children']['form-fields']['children']['city'])) {
continue;
}
// Remove or unset the "city" field
unset($billingForm['children']['form-fields']['children']['city']);
}
}
// Return the modified result
return $result;
}
}
4) Create LayoutProcessor.php
app/code/DCKAP/Popup/Plugin/Checkout/LayoutProcessor.php
<?php
/**
* Created By : Rathina Pranesh
*/
namespace DCKAP\Popup\Plugin\Checkout;
class LayoutProcessor
{
/**
* Process js Layout of block
*
* @param \Magento\Checkout\Block\Checkout\LayoutProcessor $subject
* @param array $jsLayout
* @return array
*/
public function afterProcess(
\Magento\Checkout\Block\Checkout\LayoutProcessor $subject,
array $jsLayout
) {
// Remove the "city" field
$jsLayout['components']['checkout']['children']['steps']['children']['shipping-step']['children']
['shippingAddress']['children']['shipping-address-fieldset']['children']['city']['visible'] = 0;
// Like above we can remove the "company" field also
// Remove the "phone" field
if (isset($jsLayout['components']['checkout']['children']['steps']['children']['shipping-step']['children']
['shippingAddress']['children']['shipping-address-fieldset']['children']['telephone'])) {
$jsLayout['components']['checkout']['children']['steps']['children']['shipping-step']['children']
['shippingAddress']['children']['shipping-address-fieldset']['children']['telephone']['visible'] = 0;
}
return $jsLayout;
}
}
Output for Shipping form
data:image/s3,"s3://crabby-images/c1aa9/c1aa9295692b9a277775ec5efb1157e135e7a1d3" alt=""
Output For Billing Address
data:image/s3,"s3://crabby-images/3c86e/3c86ef7c132ec87bcbea12484f8b89c07a661a3b" alt=""
Optimize Your Magento 2 Checkout by Removing Unnecessary Fields
Customizing your checkout process is crucial for improving user experience and boosting conversions. Magento 2 provides several methods to remove unnecessary fields such as city, telephone, and company from the shipping and billing address forms. Whether you choose to remove fields through plugins, these changes will make the checkout process more efficient and user-friendly for your customers.
By streamlining the checkout process, you make it easier for customers to complete their purchases without unnecessary distractions. If you need expert assistance in optimizing your Magento 2 store development, Klizer is here to help!