How to Create Custom WordPress Blocks

0
669

The WordPress block editor, also known as Gutenberg, has transformed content creation by introducing a modular block-based editing experience. While WordPress offers a growing library of core blocks, there are times when you need more flexibility or want to build something tailor-made for your website or client. That’s where custom WordPress blocks come into play.

In this blog, we’ll walk you through how to create custom WordPress blocks from scratch using modern tools like @wordpress/scripts, React, and the Block API. Whether you want to add dynamic content, branding components, or interactive elements, this guide has got you covered.

 

What is a WordPress Block?

A block is a reusable unit of content in the WordPress editor—such as a paragraph, image, button, or gallery. Blocks are built using JavaScript (mostly React) and registered with PHP. Custom blocks let you define your own functionality and design to extend Gutenberg beyond the default blocks.

 

Why Create Custom Blocks?

Here’s why you might need to build a custom block:

  • Unique functionality: For example, a pricing table, testimonial slider, or product feature block.

  • Client branding: Delivering consistent styling and user experience across the editor.

  • Reusable elements: Empower content teams to insert complex layouts without touching code.

  • Enhanced UX: Provide a better editor interface tailored to your specific use cases.

 

Prerequisites

To follow along, ensure you have the following:

  • A local WordPress development environment (e.g., using Local, MAMP, or DevKinsta)

  • Node.js and npm installed

  • Familiarity with React and JavaScript ESNext

  • Basic understanding of WordPress themes/plugins

 

Step-by-Step: Creating a Custom WordPress Block

Let’s build a simple custom "Call to Action" block.

1. Set Up a Custom Plugin

First, create a new folder in wp-content/plugins/ called custom-blocks. Inside, create a file named custom-blocks.php.

<?php

/**

 * Plugin Name: Custom Blocks

 * Description: A plugin to register custom Gutenberg blocks.

 * Version: 1.0

 */

 

defined( 'ABSPATH' ) || exit;

 

function custom_blocks_register() {

    // Automatically loads block files from build/index.js

    wp_register_script(

        'custom-blocks-editor-script',

        plugins_url( 'build/index.js', __FILE__ ),

        array( 'wp-blocks', 'wp-element', 'wp-editor', 'wp-components' ),

        filemtime( plugin_dir_path( __FILE__ ) . 'build/index.js' )

    );

 

    register_block_type( 'custom/cta-block', array(

        'editor_script' => 'custom-blocks-editor-script',

    ));

}

 

add_action( 'init', 'custom_blocks_register' );

 

2. Initialize the Block with @wordpress/scripts

Navigate into your plugin directory and initialize the block setup using:

npx @wordpress/create-block cta-block

 

This scaffolds your block with a default structure and all dependencies pre-configured.

It will create a cta-block folder with files like:

  • block.json

  • edit.js

  • save.js

  • style.scss

You can now edit your block functionality inside edit.js and save.js.

 

3. Customize the Block (Example: Call to Action)

Let’s update the editor interface to add a title and a button.

edit.js:

import { __ } from '@wordpress/i18n';

import { useBlockProps, RichText } from '@wordpress/block-editor';

 

export default function Edit({ attributes, setAttributes }) {

    const { title, buttonText } = attributes;

 

    return (

        <div {...useBlockProps()}>

            <RichText

                tagName="h2"

                value={title}

                onChange={(value) => setAttributes({ title: value })}

                placeholder={__('Add CTA title…', 'cta-block')}

            />

            <RichText

                tagName="button"

                value={buttonText}

                onChange={(value) => setAttributes({ buttonText: value })}

                placeholder={__('Click Me', 'cta-block')}

            />

        </div>

    );

}

 

save.js:

import { useBlockProps, RichText } from '@wordpress/block-editor';

 

export default function save({ attributes }) {

    const { title, buttonText } = attributes;

 

    return (

        <div {...useBlockProps.save()}>

            <RichText.Content tagName="h2" value={title} />

            <RichText.Content tagName="button" value={buttonText} />

        </div>

    );

}

 

block.json (simplified):

{

  "apiVersion": 2,

  "name": "custom/cta-block",

  "title": "Call to Action",

  "category": "widgets",

  "icon": "megaphone",

  "attributes": {

    "title": { "type": "string" },

    "buttonText": { "type": "string" }

  },

  "editorScript": "file:./index.js"

}

 

Run npm run build to compile your JavaScript files. Activate the plugin, and you’ll see your custom block in the editor!

 

Tips and Best Practices

  • Use @wordpress/scripts to simplify build tools (webpack, Babel).

  • Keep blocks modular by separating concerns (edit/save/styles).

  • Use InnerBlocks for nested content like accordions or tabs.

  • Add supports in block.json to define custom block behaviors.

  • Test responsiveness and accessibility early in development.

  • Register block styles using wp_enqueue_style.

 

Advanced Features to Explore

Once you're comfortable with the basics, explore:

  • Dynamic blocks with PHP rendering

  • Server-side attributes (great for query blocks)

  • Inspector controls (Sidebar UI)

  • Reusable components from @wordpress/components

  • Custom block styles and variations

 

Final Thoughts

Creating custom WordPress blocks gives developers the power to tailor content creation exactly to their needs. With Gutenberg's robust APIs and modern JavaScript support, you can build rich, intuitive editing experiences that save time and boost consistency across your website or product.

Whether you're a freelancer, agency, or business owner looking to streamline content management, investing in custom blocks is a future-proof move.

Sponsored
📢 System Update: Sharkbow Marketplace is Now Open!

We are excited to announce the **launch of the Sharkbow Marketplace!** 🎉 Now you can:

  • 🛍️ List and sell your products – Open your own store easily.
  • 📦 Manage orders effortlessly – Track sales and communicate with buyers.
  • 🚀 Reach thousands of buyers – Expand your business with ease.

Start selling today and grow your online business on Sharkbow! 🛒

Open Your Store 🚀
Search
Sponsored

🚀 What Can You Do on Sharkbow?

Sharkbow.com gives you endless possibilities! Explore these powerful features and start creating today:

  • 📝 Create Posts – Share your thoughts with the world.
  • 🎬 Create Reels – Short videos that capture big moments.
  • 📺 Create Watch Videos – Upload long-form content for your audience.
  • 📝 Write Blogs – Share stories, insights, and experiences.
  • 🛍️ Sell Products – Launch and manage your online store.
  • 📣 Create Pages – Build your brand, business, or project.
  • 🎉 Create Events – Plan and promote your upcoming events.
  • 👥 Create Groups – Connect and build communities.
  • Create Stories – Share 24-hour disappearing updates.

Join Sharkbow today and make the most out of these features! 🚀

Start Creating Now 🚀
Categories
Read More
Other
Plastic Recycling Market Expects to See Significant Growth During 2023-2032
The plastic recycling market has gained significant attention in recent years due to...
By Maxjoy Joy 2023-08-10 05:46:00 0 752
Other
A2 Milk Market Segmentation By Top Market Players GCMMF (Amul), Erden Creamery Private Limited, Freedom Foods Group Limited, Lion Dairy & Drinks
A2 Milk Market Share: Las Vegas, United States: Straits Research's latest report on, A2 Milk...
By Rushikesh Dhole 2022-11-28 07:53:04 0 926
Other
Pol Gallagher
Pol Gallagher The $100,000 OMG! Fund was organised by Airbnb, the online accommodation website....
By John Mark 2022-12-09 05:12:20 0 625
Other
Automotive Data Monetization Market Growth Trends Analysis | Emergen Research
The panoramic view of the Automotive Data Monetization market entails useful insights...
By Imona Vmin 2023-05-03 11:26:06 0 1K
Other
The lithium-ion battery market in India is Expected to Showcase a CAGR Of 18.5% due to Energy Storage Solutions for Microgrids | Univdatos Market Insights
According to a new report published by UnivDatos Markets Insights, the India lithium-ion battery...
By Neha Jagtap 2023-07-03 12:02:38 0 711