Create A Custom Page Template In WordPress

Once a theme has been deployed, all the pages and posts of the website reflect its design. However, you might have come across websites that have pages with different design and appearances.

Unfortunately, themes do not provide the capability of different layouts for different pages. The only way out of this issue is to opt for a custom page template.

A custom page template could be used for a number of purposes. Some ideas include:

  • Show recent posts in each category.
  • Embed Google Map or any script.
  • List of all authors.
  • Recently uploaded images.
  • Custom design page for the portfolio.
  • Contact page.

The appearance of all the pages and posts that are created on a WordPress website is handled by a template file named page.php. Creating or editing a custom page template in WordPress requires basic knowledge of HTML, CSS, and PHP.

Simply open any text editor and paste the following code into it.

The above line of code tells WordPress that it is a template file called PageWithoutSidebar. You can use any name you want. Now save this file as PageWithoutSidebar.php. Again you can use any other name for the file. But don’t forget to keep the extension as .php

Now, we’re going to test our newly created template file.

Login to your hosting panel. In this example, I am using Cloudways – A Managed WordPress Cloud Hosting. Navigate to /wp-content/themes folder. Open your current theme folder and upload PageWithoutSidebar.php file there.

Go to WordPress Admin Panel > Pages > Add New. You can see the new custom page template listed on the right side.

Create a new page and set its template to PageWithoutSidebar. Once done, Publish it.

Open the newly created page. As there are no design elements in the template yet, a blank page like the image below is displayed.

This shows that the custom page template in WordPress is successfully implemented.

It is now time to add a few lines of code to display the content of the page.

For this demo, I will discuss how you could customize the default Twenty Sixteen page template.

The default appearance of the pages is generated by page.php file located in /wp-contents/themes/YOUR THEME/ folder. Open page.php and copy this code.

Paste this code into PageWithoutSidebar.php just below this line of code.

Save it!

Your complete PageWithoutSidebar.php file will look like below.

Go back to your page and refresh it. You’ll observe everything is working in the way it does on the default WordPress Twenty Sixteen theme.

Now let us customize it. As you can see there is a sidebar on the right side. I will remove it from this page only. All other pages will have the default appearance of Twenty Sixteen theme.

Open the file PageWithoutSidebar.php file. Scroll down till the end of the file and remove:

This is the line of code that gets the sidebar on the page. After removing the line, save it. Open the page’s URL and the sidebar is no more!

As you can see, the sidebar has been successfully removed from this page. However, the text alignment is not good. There is a blank space on the right side. The fix is to justify and extend the text to fill the screen.

Go back to PageWithoutSidebar.php and find:

Just change “ contentarea ” to “ sitecontentfullwidth” and you’re done. Refresh the page and the content is full width.

Wide Content Area

Are you confused why I created a custom page template when I could have easily edited the page.php file?  It is really simple. If I had edited page.php file, all the pages across the website would show the changes. In order to change the appearance of specific pages, a custom page template in WordPress is the only way.