This article will show the WordPress theme file execution hierarchy. In a nutshell, we’ll look at what files are served when you load a page in WordPress. You probably already know that detail posts are served by single.php and detail pages are served by page.php, but WordPress searches different files based on various factors, so we’ll take a look at how that works! p>
The first thing we should determine is: without index.php and style.css, your theme is no longer a valid WordPress theme... So this is It stands to reason that if you only have these two files, then every page you try to load will be served by index.php. Take a quick look at this "cheat sheet" to see what I'm referring to:
Please note that the process for each page type will end with index.php. This is why index.php is a required file for WordPress themes. If we are missing any other file in the WordPress theme (for example, if the “search.php” file is not included in the theme), then index.php will be provided.
Now let's look at some details about the order of execution. I’m going to show you the process of WordPress searching for files in the active theme folder. I hope this is useful as you start creating WordPress themes from now on:
I will go through each type of file one by one and show the execution hierarchy of the same files.
Homepage
This is the first and most important page of any website. So WordPress provides scope for customizing pages. Let’s take a look at the file hierarchy for the home page.
- front-page.php
- home.php
- index.php
When serving a homepage, WordPress will search for front-page.php. If not found, it will use home.php. If home.php exists, it will use it. If not, it will default to index.php.
WordPress Post Details
- single-[Post type].php
- single.php
- index.php
WordPress can have as many post types as we need. So it will be easier to get different designs for all/certain post types. By default, "post" is WordPress's primary and default post type.
For example, if your custom post type is product, then it will be single-product.php
To know more about how to add a new post type in WordPress, you can refer to this link.
WordPress Page Details
- [Custom template].php
- Page-[slug].php
- Page-[id].php
- page.php
- index.php
Like post types, we can have different page layouts using custom page templates. So WordPress first searches for the file of the selected page template if it exists.
If not found, the file of the current page slug will be searched. Basically, if the slug is aboutus, then it will search for the file page-aboutus.php in the active theme folder.
WordPress will search for files with IDs just like files with slugs.
Category Page
- Category-[slug].php
- Category-[id].php
- category.php
- archive.php
- index.php
From the above process, you can understand how to use different templates for category pages. For example, you could have a custom page based on slug and id, and then use the default "category.php" file for the rest of the categories.
Bookmark page
- tag-[slug].php
- tag-[id].php
- tag.php
- archive.php
- index.php
This will be the same as category. You can also set up different pages for tag slug and tag id.
Category page
- Classification-[Tax]-[Term].php
- Category-[Tax].php
- taxonomy.php
- archive.php
- index.php
Here are the different file hierarchies for category pages.
Author page
- Author-[Author Nickname].php
- Author-[Author ID].php
- Author.php
- archive.php
- index.php
Here you will know that you can also have different designs based on the user. Same with categories and tags, we can have different files based on the user's slug and ID.
Attachment page
- [mime type].php
- Attachment.php
- single.php
- index.php
Here you can see that different types of attachments can have different page layouts. These can be distinguished from the MIME type of the attached file.
Date Page
- date.php
- archive.php
- index.php
For date specific layout, we can create date.php in the theme folder. The process then goes to archive.php and finally to index.php.
Archive Page
- archive.php
- index.php
As we move down through the file types, the number of files in the hierarchy decreases. This is the basic file or we can say the most commonly used file in any WordPress theme.
Search page
- Search.php
- index.php
You can use search.php to customize search results first. If search.php is not available, index.php will be served.
404 page
- 404.php
- index.php
If the page or post is not found, WordPress will search for 404.php and if not found, it will serve index.php.
in conclusion
Obviously you can use this information in a number of ways to load custom templates for various pages... In many cases you can get a custom solution without modifications, even if you use an existing theme Existing theme files. You just need to create the new file and give it a new name using the information above.
Share your ideas and any other files that can be included above the hierarchy.
The above is the detailed content of Execution Hierarchy of WordPress Theme Files. For more information, please follow other related articles on the PHP Chinese website!

Enable comments on your WordPress website to provide visitors with a platform to participate in discussions and share feedback. To do this, follow these steps: Enable Comments: In the dashboard, navigate to Settings > Discussions, and select the Allow Comments check box. Create a comment form: In the editor, click Add Block and search for the Comments block to add it to the content. Custom Comment Form: Customize comment blocks by setting titles, labels, placeholders, and button text. Save changes: Click Update to save the comment box and add it to the page or article.

How to copy WordPress subsites? Steps: Create a sub-site in the main site. Cloning the sub-site in the main site. Import the clone into the target location. Update the domain name (optional). Separate plugins and themes.

The steps to create a custom header in WordPress are as follows: Edit the theme file "header.php". Add your website name and description. Create a navigation menu. Add a search bar. Save changes and view your custom header.

Enable comments in WordPress website: 1. Log in to the admin panel, go to "Settings" - "Discussions", and check "Allow comments"; 2. Select a location to display comments; 3. Customize comments; 4. Manage comments, approve, reject or delete; 5. Use <?php comments_template(); ?> tags to display comments; 6. Enable nested comments; 7. Adjust comment shape; 8. Use plugins and verification codes to prevent spam comments; 9. Encourage users to use Gravatar avatar; 10. Create comments to refer to

You can install the FTP plug-in through WordPress, configure the FTP connection, and then upload the source code using the file manager. The steps include: installing the FTP plug-in, configuring the connection, browsing the upload location, uploading files, and checking that the upload is successful.

How to copy WordPress code? Copy from the admin interface: Log in to the WordPress website, navigate to the destination, select the code and press Ctrl C (Windows)/Command C (Mac) to copy the code. Copy from a file: Connect to the server using SSH or FTP, navigate to the theme or plug-in file, select the code and press Ctrl C (Windows)/Command C (Mac) to copy the code.

WordPress Error Resolution Guide: 500 Internal Server Error: Disable the plug-in or check the server error log. 404 Page not found: Check permalink and make sure the page link is correct. White Screen of Death: Increase the server PHP memory limit. Database connection error: Check the database server status and WordPress configuration. Other tips: enable debug mode, check error logs, and seek support. Prevent errors: regularly update WordPress, install only necessary plugins, regularly back up your website, and optimize website performance.

How to turn off a comment in WordPress? Specific article or page: Uncheck Allow comments under Discussion in the editor. Whole website: Uncheck "Allow comments" in "Settings" -> "Discussion". Using plug-ins: Install plug-ins such as Disable Comments to disable comments. Edit the topic file: Remove the comment form by editing the comments.php file. Custom code: Use the add_filter() function to disable comments.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Atom editor mac version download
The most popular open source editor

SublimeText3 Linux new version
SublimeText3 Linux latest version

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Zend Studio 13.0.1
Powerful PHP integrated development environment

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.