Skip to content

Part 1: Building A WordPress Theme

Calum Childs edited this page Feb 4, 2023 · 45 revisions

Hello and welcome to the Building a WordPress Theme tutorial! You'll learn how to build a basic WordPress theme from scratch to use on your own blog or website. Let's jump right in!

Installation of local environment

We'll be using Local to create a local WordPress environment. This means you'll be able to run WordPress without having to worry about web servers or hosting fees!

Before you get started with this tutorial, make sure you've downloaded and installed this software.

The basics of WordPress themes

WordPress is built using PHP and mySQL, but in recent years it has used React to make the new Gutenberg editor.

To make a WordPress theme, you must have two files: index.php and style.css.

All the files that you'll need for this tutorial are included in this GitHub repository (although they are all blank except for the style.css, as we'll find out.)

You can download these files by clicking the green "Code" button on the top-right, then by clicking "Download ZIP".

CSS

Open the theme's style.css file. At the top of the file, you'll see a comment that looks like this:

/*
Theme Name: Your WordPress Theme
Theme URI: http://yourwebsite.com/
Author: Your Name
Author URI: http://yourwebsite.com/
Description: This is your WordPress theme.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: your-wp-theme
*/

The above CSS comment has to appear at the top of the theme's style.css file. It tells WordPress information about the theme and the people that made it. Feel free to change any of the default information.

Note: If you change the text domain, make sure to replace your-wp-theme with your own text domain in this tutorial.

This theme is designed so you can change the colours and fonts it uses easily just by changing a few lines of the CSS code. We're going to do this using CSS variables. We'll define them like this:

:root {
    --font-family: 'Arial', sans-serif; // change this
    --background-colour: #FFFFFF;
    --text-colour: #111111;
    --link-colour: blue;
}

You'll see how this comes in handy as we build our WordPress theme.

Displaying the content

First, we need to tell WordPress how we want to display content on the following page types:

  • blog posts
  • static pages
  • home page
  • search results

So let's get started!

Header and Footer

Firstly, we need to display the header and footer on all our pages. There are two built-in functions that allow us to do this: get_header() (which will get our theme's header.php file and output it's contents) and get_footer() (which will get our theme's footer.php file and output it's contents.) In all of your theme's .php files (except for functions.php, header.php and footer.php) enter this code into your files:

<?php get_header(); ?>

<?php get_footer(); ?>

Extra info: If you want to have multiple headers or footers in your theme (such as a different header for your home page or a different footer for your about page), you could declare your header function as get_header('home') which would get the header-home.php file if it existed and the default header file (header.php) if if didn't.

Then go into your header.php file and enter this code:

<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="<?php echo get_stylesheet_directory_uri(); ?>/style.css">
<script src="<?php echo get_stylesheet_directory_uri(); ?>/js/script.js" type="text/javascript"></script>
<?php wp_head(); ?>
</head>
<body>
	<nav id="site-navigation" class="main-navigation">
			<button class="menu-toggle" aria-controls="primary-menu" aria-expanded="false">Menu</button>
			<?php
			wp_nav_menu(
				array(
					'theme_location' => 'menu-1',
					'menu_id'        => 'primary-menu',
				)
			);
			?>
	</nav>

The wp_head() function acts as a hook for plugins and core WordPress functions to add stylesheets and scripts to the website.

The wp_nav_menu() function gets the items in the primary menu.

Now go into your footer.php file and enter this code:

<footer>
<p>&copy; <?php bloginfo('name'); ?> 2023 All Rights Reserved</p>
<?php wp_footer(); ?>
</footer>
</body>
</html>

The wp_footer() function is similar to the wp_head() function, except it's for the footer. It should always be placed before the </body> tag.

The bloginfo('name') function gets the website's name.

The Loop

If you're creating a blog, you'll want all your blog posts to be displayed on the front page of the website. The code that displays each blog post is called The Loop. Below is an example of a list of blog posts being displayed on a WordPress website:

image

To do this, go to index.php and on the line after the get_header() function, create an if statement like this:

<?php
<?php get_header(); ?>
<h1 class="site-title align-center">Welcome to <?php bloginfo('name'); ?>!</h1>
<h2 class="site-tagline align-center"><?php bloginfo('description'); ?></h2>
<?php
if ( have_posts() ) :
    while ( have_posts() ) :
        the_post();
?>
<div class="post">
    <h2 class="post-title"><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a></h2>
    <p class="post-excerpt"><?php the_excerpt(); ?></p>
    <a class="button" href="<?php the_permalink(); ?>">Read more...</a>
</div>
<?php endwhile; ?>
<?php endif; ?>
<?php get_footer(); ?>

There's several functions in The Loop. Here's what each of them do:

  • have_posts() checks to see if there are any posts
  • the_post() gets the current post information [check this]
  • the_title() gets the post's title
  • the_excerpt() gets a preview of the blog post (usually the first 50 characters, but you can manually change the excerpt of a post if you wanted to)
  • the_permalink() gets the blog post's URL

Next up, we're going to be displaying individual posts and pages on our website.

Extra info: index.php is the default file used if WordPress can't find a template for what it's displaying in your theme (such as a blog post or page).

Posts and Pages

To display posts and pages differently, we'll need to use two different templates: single.php and page.php. The single.php template dictates how a blog post will be displayed. The page.php template dictates how pages are displayed.

Extra info: If there isn't a page.php template but there is a single.php template, it will use single.php to display the page.

In the single.php file, write this code on the line after the get_header() function:

<?php
    while ( have_posts() ):
      the_post();
?>
<h1 class="post-title"><?php the_title(); ?></h1>
<p align="center"><?php echo get_the_date(); ?> | <?php the_category(', '); ?></p>
<?php the_content(); ?>
<?php endwhile; ?>
<?php the_post_navigation(); ?>

Here's what each of those functions that we haven't seen already do:

  • the_content() gets the post or page's content
  • get_the_date() gets the date the blog post was published
  • the_category() gets all the categories that the blog post is part of and separates them with a comma and a space (', ')
  • the_post_navigation() displays links to the previous and next posts

The code in page.php is roughly the same as above, but with a few minor changes, as you'll see below:

<?php
    while ( have_posts() ):
      the_post();
?>
<h1 class="page-title"><?php the_title(); ?></h1>
<p align="center"><?php echo get_the_date(); ?></p>
<?php the_content(); ?>

Home Page

On some websites, for whatever reason, you want a custom home page rather than a list of blog posts. WordPress allows you to define this in your theme relatively easily in the front-page.php file!

image

image

image

image

Extension 1: Add a sidebar

Try to add a sidebar to your website. When you've managed to do that, add a search bar and a list of the latest posts to your new sidebar.

(Hint: One of the steps requires you to add the get_sidebar() function in certain places within your code.)

Extension 2: Install some plugins

There are over 60,000 WordPress plugins that you can install! Have a look and install some plugins that you like the look of (but don't install anything with WooCommerce in the name just yet, we'll be doing that next!)

Note: When you're creating your own WordPress websites, only install and activate plugins that are absolutely necessary. The more plugins you have, the slower your website will be and the more security vulnerabilities there could be in your website.

Extension 3: Try to make your WordPress theme release-ready

Most WordPress themes that are used on websites are on the WordPress Theme Directory. Using the WordPress Theme Developers Handbook and other resources, try to make your theme ready to be released into the WordPress Theme Directory.

Clone this wiki locally