WordPress has over 54,000 plugins, some of which have millions of active installations. Regardless of where you stand on your WordPress developer journey, at some point you’ll wonder how to create a WordPress plugin.
They’re extremely useful, after all. Plugins can help you automate or improve upon native WordPress features or even create entirely new ones. But how do you create and install one on your site?
That’s the question we’ll be answering in this article. Keep reading to learn how to create a plugin in five steps.
What is a WordPress plugin?
Plugins are code packages that allow you to extend or modify your WordPress site’s functionality and features without changing the WordPress core, the codebase that powers the platform. While themes are code packages that modify your website’s appearance, plugins modify how it fundamentally works.
Plugins serve many different purposes, such as setting up sitemaps, building a site more user-friendly, improving your site’s security or SEO, adding social media sharing buttons, creating web forms, and much more.
data:image/s3,"s3://crabby-images/14c96/14c9672ebb493a7916ca0d8b45120ba1b3c5adbe" alt="various plugins in WordPress's plugin library"
As you can see, WordPress plugins solve needs that website owners and developers experience. They help customize and tailor your site to solve the problems it faces. But how do you develop a WordPress plugin?
Developing a plugin essentially comes down to coding PHP scripts that alter website behavior. As a result, you need at least basic PHP knowledge. Additionally, depending on your goals and the functions you’re trying to implement, you may also need to learn HTML, CSS, and JavaScript.
That may sound intimidating and time-consuming, and it can be. But that shouldn’t stop you from creating basic plugins to help you learn more about the platform on your journey to becoming a full-stack WordPress developer. Let’s walk through the steps of creating a simple plugin to show that, when you break down the process, it can be much more approachable than it seems at first.
How to create a basic WordPress plugin in 5 steps
Step 1: Get the necessary tools
You need only two software tools to create and test a WordPress plugin:
- A text editor to code your plugin. You can use Notepad on Windows or TextEdit on Mac, but we recommend using a dedicated code editor. Our developers use Visual Studio Code.
- A WordPress environment to test your plugin. It can be a local or an STG environment. We don’t recommend testing a plugin on your live site, even if you create a backup first.
With these tools, you can code and test your plugin before deploying it on a live WordPress site.
Step 2: Create the plugin folder and file
Create a new folder on your local machine or use an FTP client like FileZilla to browse your STG site’s folders and create a new folder. We created a new folder on Mac’s Finder app.
data:image/s3,"s3://crabby-images/6cbe7/6cbe786289cffc86146f3e0f1f8cfbb4994ad406" alt="screenshot of folder containing the plugin's files"
Now, create the PHP file to add the plugin’s code. Best practices suggest that the file should have the exact same name as the folder, followed by the .php
extension. Therefore, we created a file called my-test-plugin.php
and are ready to add the code using Visual Studio Code.
data:image/s3,"s3://crabby-images/89d87/89d8778a8ec9fc28505f5e53269feaf9928f44f2" alt="screenshot of plugin's PHP file in Visual Studio code"
Remember that you can also use a plain text editor like Notepad or EditText. Still, we recommend Visual Studio Code or another code editor like Codespaces or Sublime Text.
Step 3: Code your plugin
Now it’s time to add the code to extend or modify your WordPress site’s functions. First, let’s add the plugin’s header, containing general information about it.
<?php
/**
* Plugin Name: my-test-plugin
* Plugin URI: https://wcanvas.com/
* Description: This is a test plugin.
* Version: 1.0
* Author: White Canvas
* Author URI: https://wcanvas.com/
**/
Edit this header to match your plugin’s data.
Technically, you could use this plugin as-is. You could upload it to your local/STG environment, and it would work… but it would do nothing. Let’s add code below the header to display a text message at the bottom of every blog post.
function wcanvas_read_our_blog($content) {
// This line ensures the plugin only activates in individual posts.
if ( is_single() ) {
// Display a message at the bottom of the post.
$content .= '<p class="read-our-blog">If you found this post useful, <a href="https://wcanvas.com/blogs/" title="White Canvas blog archive" target="_blank" rel="nofollow">read our blog</a> for more WordPress insights.</p>';
}
return $content;
}
add_filter('the_content', 'wcanvas_read_our_blog');
That’s it! This is your first plugin! You’ve created a plugin that adds text containing a link to the White Canvas blog (change the URL to link wherever you want) at the bottom of every post. Now let’s upload the plugin, activate it, and see it in action on your site.
Step 4: Test your plugin on your local or STG environment
Now it’s time to test your new plugin. To do that, you’ll have to:
- Compress your plugin’s folder.
- Upload your plugin to your local or STG environment.
- See your plugin in action.
Compress your plugin’s folder
On Mac, right-click your plugin’s folder and select “Compress [your folder’s name]”.
data:image/s3,"s3://crabby-images/f87bf/f87bfba1a5858acad2c56e59487c91fcc27a4222" alt="screenshot of "Compress" option in Mac's Finder"
This will result in a .zip file you can upload into your WordPress site.
data:image/s3,"s3://crabby-images/d0a18/d0a181f0e5726cf800575d5340b29bc83c0d81ac" alt="screenshot of compressed plugin folder"
Upload your plugin into your WordPress environment
On the WordPress admin panel, go to Plugins > Add New. At the top, click on Upload Plugin.
data:image/s3,"s3://crabby-images/946c9/946c9e3b671af91944f9ba2642be879c7d32b9c1" alt="screenshot of WordPress's plugin library, pointing at Upload button"
Click on Choose File and browse to your plugin’s .zip file.
data:image/s3,"s3://crabby-images/4ff03/4ff036e966007ca6054288a42381c72c2bf68cc9" alt="Choose File button in WordPress's plugin directory"
Then click on Install Now.
data:image/s3,"s3://crabby-images/aa601/aa601632c61bce606a1a7910a52b0f34499c6573" alt="Install Now button in WordPress's plugin directory"
Click on Activate Plugin.
data:image/s3,"s3://crabby-images/3d69f/3d69f5043d13314fa1fa242780ad67cc9a269881" alt="Activate Plugin button in WordPress's plugin directory"
You’ll move to the Installed Plugins screen, where you’ll see your newly-created plugin.
data:image/s3,"s3://crabby-images/8d2f5/8d2f5aa273ee25a9c45f10146e8ce0d4f7bb6385" alt="your plugin in the WordPress admin Plugins section"
See your plugin in action
This plugin should activate on the live version of every individual post (not on the backend editor). Go to any post and click Preview.
data:image/s3,"s3://crabby-images/861cb/861cb84b3daa7afde88fecc239eba894ae56bddc" alt="highlight of the Preview button in the post editor"
You should see the message in the PHP file at the bottom of the post!
data:image/s3,"s3://crabby-images/1de3d/1de3dc6877bc8dc1b5b050feb808c33f3a4e03ec" alt="highlight of the text introduced with the plugin we developed"
Success!
Step 5: Submit your plugin to the WordPress directory
Submitting your plugin lets other WordPress users download and install it on their sites, too. However, submitting your plugin and having it approved takes around 1 to 10 days (or more), depending on its complexity.
Furthermore, it has to adhere to WordPress’s plugin guidelines to ensure that it’s safe for users, doesn’t qualify as trialware, is stable, etc.
To start the process of submitting your plugin, click here.
Wrapping up
Creating a WordPress plugin involves basic computer skills and coding in PHP, HTML, CSS, and JavaScript. At its most basic, plugins are PHP files that modify or extend your site’s functionalities to solve problems and needs, like creating forms or adding social media sharing buttons.
The more complex plugins involve multiple programming languages and complicated functions. In this article, we walked you through the steps for coding a rudimentary plugin that simply displays a message at the bottom of every post. It serves as a good introduction to the fundamentals. As you advance through your WordPress developer journey, you can create more complex plugins that solve real needs!
If you found this article helpful, check out our blog for more WordPress guides and insights.
Related Articles
data:image/s3,"s3://crabby-images/1f7fb/1f7fb931623e88f9c235ee7e65095ac57dfecd24" alt="a hand typing on a computer keyboard with a login form overlayed on top"
How to... / 5 min read
How to... / 5 min read
How to Make a Subscriber Into an Admin on WordPress?
While it's not the most common situation, at some point, you may find yourself needing to make a Subscriber into an Admin on your WordPress site. Maybe you need to…
Read Moredata:image/s3,"s3://crabby-images/e77c4/e77c48ffb51e65e7273fe034f7c5273e11d0b4d7" alt=""
How to... / 3 min read
How to... / 3 min read
How to Grant Secure Access to a Not Live WordPress Site During Development
When developing a WordPress site, you often need to collaborate with multiple developers and grant access to the website owner so they can review the progress themselves. However, granting access…
Read Moredata:image/s3,"s3://crabby-images/c782d/c782de0520d9508629dbe536f9f6547ef2903d3e" alt="man writing programming code while wearing headphones"
Industry Insights / 11 min read
Industry Insights / 11 min read
Do You Need a Web Developer to Build a WordPress Site?
If you’re building a WordPress site or considering building one, you wonder whether you need a web developer to create it or you can do it yourself. The answer can…
Read Moredata:image/s3,"s3://crabby-images/09607/096074a1582c186d9a62fdc1d77187f9b48d195a" alt=""
How to... / 6 min read
How to... / 6 min read
How to Change the Bottom Padding Dimensions on WordPress Blocks
If you're learning to modify your WordPress site's layouts and design, you may be wondering how to change the bottom padding dimensions of some of its elements. If that's the…
Read Moredata:image/s3,"s3://crabby-images/6a081/6a08118b31b96f1a8aee592aa5690508fb8e7179" alt="close up of a laptop running a website that displays various types of content"
How to... / 10 min read
How to... / 10 min read
How to Disable the “Similar Posts” Section in WordPress Blogs
If you’re diving deeper into customizing your site, you may be wondering how to disable the “Similar Posts” section that appears on the bottom, sidebar, or footer of your WordPress…
Read More